<?xml version="1.0" encoding="utf-8" standalone="yes"?>
<rss version="2.0" xmlns:atom="http://www.w3.org/2005/Atom" xmlns:content="http://purl.org/rss/1.0/modules/content/">
  <channel>
    <title>编程 on MoeJue&#39;s Blog</title>
    <link>https://en.moejue.cn/ja/tags/%E7%BC%96%E7%A8%8B/</link>
    <description>Recent content in 编程 on MoeJue&#39;s Blog</description>
    <generator>Hugo -- 0.151.2</generator>
    <language>ja</language>
    <lastBuildDate>Sat, 10 Jan 2026 14:02:35 +0000</lastBuildDate>
    <atom:link href="https://en.moejue.cn/ja/tags/%E7%BC%96%E7%A8%8B/index.xml" rel="self" type="application/rss+xml" />
    <item>
      <title>Web3 オンチェーン紅包 DApp</title>
      <link>https://en.moejue.cn/ja/posts/303/</link>
      <pubDate>Sat, 10 Jan 2026 14:02:35 +0000</pubDate>
      <guid>https://en.moejue.cn/ja/posts/303/</guid>
      <description>&lt;p&gt;これは&lt;strong&gt;100%分散型&lt;/strong&gt;のブロックチェーンお年玉（レッドパケット）アプリケーションです。ユーザーはウォレットを接続し、金額と数量を設定してお年玉を送信し、リンクを通じて他の人と共有して受け取ることができます。すべてのデータと操作はブロックチェーンに基づいており、中央集権型サーバーは一切不要で、プロセス全体が安全、透明、追跡可能です。&lt;/p&gt;
&lt;p&gt;興味があれば、GitHubで私のコードをご覧ください：&lt;a href=&#34;https://github.com/iAJue/redpacket-dapp&#34;&gt;redpacket‑dapp&lt;/a&gt;&lt;/p&gt;
&lt;h2 id=&#34;機能ハイライト&#34;&gt;機能ハイライト&lt;/h2&gt;
&lt;ul&gt;
&lt;li&gt;🧧 &lt;strong&gt;お年玉の送信&lt;/strong&gt;: ウォレットを接続後、金額と数量を設定してブロックチェーンにお年玉を送信します。&lt;/li&gt;
&lt;li&gt;🎁 &lt;strong&gt;お年玉の受け取り&lt;/strong&gt;: 共有リンクを通じて、他の人はウォレットを接続してブロックチェーンから直接お年玉を受け取ることができます。&lt;/li&gt;
&lt;li&gt;🔗 &lt;strong&gt;スマートコントラクト&lt;/strong&gt;: Solidityで書かれた安全なスマートコントラクトがすべてのロジックを処理します。&lt;/li&gt;
&lt;li&gt;🌐 &lt;strong&gt;マルチチェーン対応&lt;/strong&gt;: ローカルテストネットとBSCテストネットをサポートします。&lt;/li&gt;
&lt;li&gt;💼 &lt;strong&gt;Web3統合&lt;/strong&gt;: MetaMaskウォレットを使用して接続します。&lt;/li&gt;
&lt;li&gt;🚀 &lt;strong&gt;完全分散型&lt;/strong&gt;: バックエンドサーバーがなく、すべてのデータはブロックチェーンに保存されます。&lt;/li&gt;
&lt;/ul&gt;
&lt;h2 id=&#34;技術スタック&#34;&gt;技術スタック&lt;/h2&gt;
&lt;ul&gt;
&lt;li&gt;&lt;strong&gt;フロントエンド&lt;/strong&gt;：React 19、React Router 6、TypeScript、Vite、Ethers v6&lt;/li&gt;
&lt;li&gt;&lt;strong&gt;コントラクト層&lt;/strong&gt;：Hardhat、Solidity 0.8.x&lt;/li&gt;
&lt;li&gt;&lt;strong&gt;ツール&lt;/strong&gt;：ESLint、Prettier&lt;/li&gt;
&lt;li&gt;&lt;strong&gt;バックエンド不要&lt;/strong&gt;: サーバーへの依存なし ❌&lt;/li&gt;
&lt;/ul&gt;
&lt;h2 id=&#34;クイックスタート&#34;&gt;クイックスタート&lt;/h2&gt;
&lt;pre&gt;&lt;code&gt;# 1. プロジェクトの依存関係をインストール
npm install
cd react-dapp &amp;amp;&amp;amp; npm install &amp;amp;&amp;amp; cd ..

# 2. ローカルブロックチェーンノードを起動
npm run node

# 3. スマートコントラクトをコンパイル
npx hardhat compile

# 4. スマートコントラクトをデプロイ
npm run deploy

# 5. フロントエンドを起動
npm run frontend
&lt;/code&gt;&lt;/pre&gt;
&lt;h2 id=&#34;ディレクトリ構造&#34;&gt;ディレクトリ構造&lt;/h2&gt;
&lt;pre&gt;&lt;code&gt;redpacket-web3/
├─ contracts/                # Solidity スマートコントラクト
│  └─ RedPacket.sol
├─ react-dapp/               # React + Vite フロントエンド
│  ├─ src/
│  │  ├─ components/         # 共通コンポーネント（ウォレットボタン、作成フォームなど）
│  │  ├─ config/             # ABI、コントラクトアドレス設定
│  │  ├─ hooks/              # カスタムフック（useWallet）
│  │  ├─ pages/              # ページ（Home、ClaimPacket）
│  │  ├─ styles/             # グローバルスタイル
│  │  ├─ utils/              # Web3 ユーティリティ関数
│  │  └─ App.tsx             # ルーティングとレイアウト
│  ├─ .env.example           # フロントエンドに必要な環境変数説明
│  └─ package.json
├─ scripts/
│  └─ deploy.js              # Hardhat デプロイスクリプト（自動的にフロントエンド設定に書き込みます）
├─ hardhat.config.js
└─ package.json              # ルートディレクトリのスクリプト（Hardhat + フロントエンドをワンクリックで起動）
&lt;/code&gt;&lt;/pre&gt;
&lt;h2 id=&#34;使用ガイド&#34;&gt;使用ガイド&lt;/h2&gt;
&lt;h3 id=&#34;お年玉の作成&#34;&gt;お年玉の作成&lt;/h3&gt;
&lt;ol&gt;
&lt;li&gt;フロントエンドを開き、右上の「ウォレットを接続」をクリックします。&lt;/li&gt;
&lt;li&gt;お年玉の総額と個数を入力すると、アプリケーションがフロントエンドで金額をランダムに分割します。&lt;/li&gt;
&lt;li&gt;送信後、MetaMaskでトランザクションを確認し、ブロックの承認を待ちます。&lt;/li&gt;
&lt;li&gt;成功後、システムが生成した受け取りリンクをコピーして友人と共有できます。&lt;/li&gt;
&lt;/ol&gt;
&lt;h3 id=&#34;お年玉の受け取り&#34;&gt;お年玉の受け取り&lt;/h3&gt;
&lt;ol&gt;
&lt;li&gt;共有リンク（URLに &lt;code&gt;/claim/{packetId}&lt;/code&gt; が含まれる）を開きます。&lt;/li&gt;
&lt;li&gt;同様にまずウォレットを接続し、「クリックして受け取る」をクリックします。&lt;/li&gt;
&lt;li&gt;署名確認後、ブロックのパッケージングを待ち、ページに結果と残り個数が表示されます。&lt;/li&gt;
&lt;/ol&gt;
&lt;h2 id=&#34;環境変数&#34;&gt;環境変数&lt;/h2&gt;
&lt;ul&gt;
&lt;li&gt;&lt;code&gt;dapp/.env&lt;/code&gt;（開発環境では自動的に無視されます。&lt;code&gt;.env.example&lt;/code&gt;を参照してください）
&lt;ul&gt;
&lt;li&gt;&lt;code&gt;VITE_RPC_URL&lt;/code&gt;：フロントエンドが直接接続するノードRPC、デフォルトは &lt;code&gt;http://127.0.0.1:8545&lt;/code&gt;&lt;/li&gt;
&lt;li&gt;&lt;code&gt;VITE_CONTRACT_ADDRESS&lt;/code&gt;：デプロイスクリプトによって書き込まれたアドレスを上書きできます。&lt;/li&gt;
&lt;li&gt;&lt;code&gt;VITE_CHAIN_ID&lt;/code&gt;：フロントエンドが使用するチェーンID（16進数）&lt;/li&gt;
&lt;/ul&gt;
&lt;/li&gt;
&lt;li&gt;&lt;code&gt;root/.env&lt;/code&gt;：Hardhatで秘密鍵やBSC RPCを参照する必要がある場合は、既存の記述をそのまま使用できます。&lt;/li&gt;
&lt;/ul&gt;
&lt;h2 id=&#34;スマートコントラクトredpacketsol&#34;&gt;スマートコントラクト（RedPacket.sol）&lt;/h2&gt;
&lt;p&gt;コアメソッド：&lt;/p&gt;</description>
    </item>
    <item>
      <title>AEはできませんが、コードは書けます</title>
      <link>https://en.moejue.cn/ja/posts/280/</link>
      <pubDate>Sat, 23 Aug 2025 12:29:01 +0000</pubDate>
      <guid>https://en.moejue.cn/ja/posts/280/</guid>
      <description>&lt;h2 id=&#34;-緒山まひろの隠れ家-&#34;&gt;✨ 緒山まひろの隠れ家 ✨&lt;/h2&gt;
&lt;p&gt;&lt;img alt=&#34;緒山まひろ&#34; loading=&#34;lazy&#34; src=&#34;https://mahiro.moejue.cn/static/images/onimai.png&#34;&gt;&lt;/p&gt;
&lt;h3 id=&#34;-緒山まひろの隠れ家へようこそ-&#34;&gt;🌸 緒山まひろの隠れ家へようこそ 🌸&lt;/h3&gt;
&lt;p&gt;&lt;img alt=&#34;緒山まひろ&#34; loading=&#34;lazy&#34; src=&#34;https://mahiro.moejue.cn/static/images/Mahiro06.png&#34;&gt;&lt;/p&gt;
&lt;p&gt;わぁ！私の秘密基地を見つけちゃったんだね！(*≧ω≦)&lt;/p&gt;
&lt;p&gt;ここは緒山まひろの個人サイトだよ。かわいいアニメーションと面白いコンテンツがいっぱい！ ここでは、私のお気に入りのアニメ、マンガ、ゲーム、そして日常のささやかな幸せをシェアしていくね～&lt;/p&gt;
&lt;h3 id=&#34;-私について-&#34;&gt;💕 私について 💕&lt;/h3&gt;
&lt;p&gt;私は緒山まひろ。エロゲを愛する引きこもりのダメニートだよ。 アニメ、マンガ、ライトノベル、そしてかわいいものが大好き！ 好きな色はピンクと水色！&lt;/p&gt;
&lt;pre tabindex=&#34;0&#34;&gt;&lt;code&gt;  ∩∩
（･ω･）  &amp;lt;- 私だよ！
＿|　⊃／(＿＿
／ └-(＿＿＿／
&lt;/code&gt;&lt;/pre&gt;&lt;p&gt;&lt;img alt=&#34;緒山まひろ&#34; loading=&#34;lazy&#34; src=&#34;https://mahiro.moejue.cn/static/images/visual_chara_mahiro-mihari.webp&#34;&gt;&lt;/p&gt;
&lt;h3 id=&#34;-サイトコンテンツ-&#34;&gt;🎀 サイトコンテンツ 🎀&lt;/h3&gt;
&lt;ul&gt;
&lt;li&gt;🌟 素敵なアニメーション&lt;/li&gt;
&lt;li&gt;📚 私のプライベートフォト&lt;/li&gt;
&lt;li&gt;🎵 おすすめの音楽&lt;/li&gt;
&lt;li&gt;📷 日常のワンシーン&lt;/li&gt;
&lt;/ul&gt;
&lt;h3 id=&#34;-関連リンク-&#34;&gt;🌈 関連リンク 🌈&lt;/h3&gt;
&lt;ul&gt;
&lt;li&gt;🎭 デモ: &lt;a href=&#34;https://mahiro.moejue.cn/&#34;&gt;https://mahiro.moejue.cn/&lt;/a&gt;&lt;/li&gt;
&lt;li&gt;🏠 個人ブログ: &lt;a href=&#34;https://MoeJue.cn/&#34;&gt;https://MoeJue.cn/&lt;/a&gt;&lt;/li&gt;
&lt;li&gt;🐱 GitHub: &lt;a href=&#34;https://github.com/iAJue/Mahiro&#34;&gt;https://github.com/iAJue/Mahiro&lt;/a&gt;&lt;/li&gt;
&lt;li&gt;📧 公式サイト: &lt;a href=&#34;https://onimai.jp/&#34;&gt;https://onimai.jp/&lt;/a&gt;&lt;/li&gt;
&lt;/ul&gt;
&lt;h3 id=&#34;-著作権情報-&#34;&gt;📝 著作権情報 📝&lt;/h3&gt;
&lt;ul&gt;
&lt;li&gt;このサイトは @Moejue によってデザイン・開発されました&lt;/li&gt;
&lt;li&gt;サイト内で使用されているすべてのアニメーション、マンガの画像、キャラクター、および関連コンテンツの著作権は、原作者（ねことうふ）およびその発行元（スタジオバインド、一迅社）に帰属します&lt;/li&gt;
&lt;li&gt;著作権侵害の可能性がある場合は、上記の連絡先までお知らせください。速やかに関連コンテンツを削除いたします&lt;/li&gt;
&lt;li&gt;GNU GENERAL PUBLIC LICENSE Version 2&lt;/li&gt;
&lt;li&gt;Copyright © 2025 MoeJue. All rights reserved.&lt;/li&gt;
&lt;/ul&gt;
&lt;h3 id=&#34;-スペシャルサンクス-&#34;&gt;💌 スペシャルサンクス 💌&lt;/h3&gt;
&lt;p&gt;緒山まひろを好きでいてくれるみんな、ありがとう！(●&amp;rsquo;◡&amp;rsquo;●)&lt;/p&gt;</description>
    </item>
    <item>
      <title>マルチチェーン対応は、想像以上に複雑だ</title>
      <link>https://en.moejue.cn/ja/posts/269/</link>
      <pubDate>Sat, 05 Jul 2025 08:20:55 +0000</pubDate>
      <guid>https://en.moejue.cn/ja/posts/269/</guid>
      <description>&lt;h4 id=&#34;初めてのマルチチェーンウォレット統合の実践的考察&#34;&gt;初めてのマルチチェーンウォレット統合の実践的考察&lt;/h4&gt;
&lt;p&gt;ようやく時間ができてコードを整理できるようになりました。Web3プロジェクトでマルチチェーンウォレット接続機能を導入する際、主にEthereum、Polygon、BSC、Solanaが関わってきます。一見すると「互換性のあるロジックをいくつか追加するだけ」のように思えますが、実際に実装してみると、多くのことが思ったほど単純ではないと気づきました。&lt;/p&gt;
&lt;pre tabindex=&#34;0&#34;&gt;&lt;code&gt;this.networkConfigs = {
    ethereum: {
        chainId: &amp;#39;0x1&amp;#39;, // 1
        chainName: &amp;#39;Ethereum Mainnet&amp;#39;,
        nativeCurrency: {
            name: &amp;#39;Ethereum&amp;#39;,
            symbol: &amp;#39;ETH&amp;#39;,
            decimals: 18
        },
        rpcUrls: [&amp;#39;https://eth-mainnet.public.blastapi.io&amp;#39;],
        blockExplorerUrls: [&amp;#39;https://etherscan.io&amp;#39;]
    },
    polygon: {
        chainId: &amp;#39;0x89&amp;#39;, // 137
        chainName: &amp;#39;Polygon Mainnet&amp;#39;,
        nativeCurrency: {
            name: &amp;#39;MATIC&amp;#39;,
            symbol: &amp;#39;MATIC&amp;#39;,
            decimals: 18
        },
        rpcUrls: [&amp;#39;https://polygon-rpc.com&amp;#39;],
        blockExplorerUrls: [&amp;#39;https://polygonscan.com&amp;#39;]
    },
    bsc: {
        chainId: &amp;#39;0x38&amp;#39;, // 56
        chainName: &amp;#39;BNB Smart Chain&amp;#39;,
        nativeCurrency: {
            name: &amp;#39;BNB&amp;#39;,
            symbol: &amp;#39;BNB&amp;#39;,
            decimals: 18
        },
        rpcUrls: [&amp;#39;https://bsc-dataseed.binance.org&amp;#39;],
        blockExplorerUrls: [&amp;#39;https://bscscan.com&amp;#39;]
    }
}
&lt;/code&gt;&lt;/pre&gt;&lt;h4 id=&#34;マルチチェーンは単に複数のウォレットをサポートすることではない&#34;&gt;マルチチェーンは単に「複数のウォレットをサポートする」ことではない&lt;/h4&gt;
&lt;p&gt;最も強く感じたのは、チェーンが異なればウォレットのインタラクション方法も異なり、SDKの考え方すら違うということです。イーサリアムエコシステムでは統一されたWeb3.jsで多くのロジックを処理できますが、Solanaになると、完全に別のシステムであることがわかります。プロバイダーの接続、接続フロー、PublicKeyの構築方法が異なり、ネットワークの遅延や安定性までもがユーザー体験に影響を与えます。&lt;/p&gt;</description>
    </item>
    <item>
      <title>macOS風のWebアプリを構築する</title>
      <link>https://en.moejue.cn/ja/posts/260/</link>
      <pubDate>Sun, 11 May 2025 11:46:03 +0000</pubDate>
      <guid>https://en.moejue.cn/ja/posts/260/</guid>
      <description>&lt;h3 id=&#34;プロジェクト概要&#34;&gt;プロジェクト概要&lt;/h3&gt;
&lt;p&gt;今日のWeb開発分野において、ユーザーエクスペリエンスとインターフェースデザインはますます重要になっています。&lt;/p&gt;
&lt;p&gt;Mac Web Vue Templateは、macOSのデザインにインスパイアされた、モダンでエレガントなVue.jsのWebテンプレートです。Vue.jsをベースにした現代的なWebアプリケーションテンプレートであり、そのデザインはmacOSの優雅なインターフェースから着想を得ています。このプロジェクトは、美しいUIデザインだけでなく、完全なプロジェクト構造とベストプラクティスも提供します。&lt;/p&gt;
&lt;h4 id=&#34;オンラインデモ&#34;&gt;オンラインデモ&lt;/h4&gt;
&lt;p&gt;&lt;a href=&#34;https://mac.moejue.cn/&#34;&gt;WebAi&lt;/a&gt; にアクセスすることで、このテンプレートの実際の効果を体験できます。招待コード(MoeJue)&lt;/p&gt;
&lt;h3 id=&#34;主な特徴&#34;&gt;主な特徴&lt;/h3&gt;
&lt;ol&gt;
&lt;li&gt;
&lt;p&gt;&lt;strong&gt;macOS風のUIデザイン&lt;/strong&gt;&lt;/p&gt;
&lt;ul&gt;
&lt;li&gt;macOSのデザイン言語を採用&lt;/li&gt;
&lt;li&gt;洗練されたすりガラス効果&lt;/li&gt;
&lt;li&gt;エレガントなアニメーショントランジション&lt;/li&gt;
&lt;/ul&gt;
&lt;/li&gt;
&lt;li&gt;
&lt;p&gt;&lt;strong&gt;モダンな技術スタック&lt;/strong&gt;&lt;/p&gt;
&lt;ul&gt;
&lt;li&gt;Vue.jsをコアフレームワークとして使用&lt;/li&gt;
&lt;li&gt;Viteをビルドツールとして使用&lt;/li&gt;
&lt;li&gt;Piniaによる状態管理&lt;/li&gt;
&lt;li&gt;Vue Routerによるルーティング処理&lt;/li&gt;
&lt;li&gt;SCSSプリプロセッサ&lt;/li&gt;
&lt;li&gt;ES6+のモダンな機能&lt;/li&gt;
&lt;/ul&gt;
&lt;/li&gt;
&lt;li&gt;
&lt;p&gt;&lt;strong&gt;レスポンシブデザイン&lt;/strong&gt;&lt;/p&gt;
&lt;ul&gt;
&lt;li&gt;あらゆる画面サイズに完璧に対応&lt;/li&gt;
&lt;li&gt;スムーズなモバイル体験&lt;/li&gt;
&lt;/ul&gt;
&lt;/li&gt;
&lt;/ol&gt;
&lt;h3 id=&#34;プロジェクト構造の解説&#34;&gt;プロジェクト構造の解説&lt;/h3&gt;
&lt;p&gt;プロジェクトは、明確でモジュール化されたディレクトリ構造を採用しています：&lt;/p&gt;
&lt;pre tabindex=&#34;0&#34;&gt;&lt;code&gt;src/
├── assets/          # 静的リソース
├── components/      # Vueコンポーネント
│   ├── common/     # 共通コンポーネント
│   ├── system/     # システムコンポーネント
│   └── apps/       # アプリケーションコンポーネント
├── views/          # ページビュー
├── router/         # ルーティング設定
├── stores/         # 状態管理
└── utils/          # ユーティリティ関数
&lt;/code&gt;&lt;/pre&gt;&lt;p&gt;この構造設計により、プロジェクトは良好な保守性と拡張性を備えています。&lt;/p&gt;
&lt;h3 id=&#34;開発規範&#34;&gt;開発規範&lt;/h3&gt;
&lt;p&gt;プロジェクトは厳格な開発規範に従っています：&lt;/p&gt;
&lt;ol&gt;
&lt;li&gt;
&lt;p&gt;&lt;strong&gt;命名規則&lt;/strong&gt;&lt;/p&gt;</description>
    </item>
    <item>
      <title>萌音ストア モバイル版 発売</title>
      <link>https://en.moejue.cn/ja/posts/256/</link>
      <pubDate>Thu, 17 Apr 2025 09:07:11 +0000</pubDate>
      <guid>https://en.moejue.cn/ja/posts/256/</guid>
      <description>&lt;h3 id=&#34;プロジェクト紹介&#34;&gt;プロジェクト紹介&lt;/h3&gt;
&lt;p&gt;萌音商城モバイル版は、uniappをベースに開発されたマルチプラットフォームECシステムで、iOS、Android、H5、ミニプログラムなど複数のプラットフォームをサポートしています。システムはPHP + MySQL + FastAdminをバックエンド技術スタックとして採用し、完全なEC機能を実現しています。&lt;/p&gt;
&lt;h3 id=&#34;主要機能&#34;&gt;主要機能&lt;/h3&gt;
&lt;ul&gt;
&lt;li&gt;商品管理：カテゴリ分け、リスト表示、詳細表示&lt;/li&gt;
&lt;li&gt;ショッピングフロー：カート、決済、支払い、注文管理&lt;/li&gt;
&lt;li&gt;ユーザーシステム：会員センター、個人情報管理&lt;/li&gt;
&lt;li&gt;マルチベンダーモード：ベンダーが独立して商品と注文を管理&lt;/li&gt;
&lt;li&gt;配送システム：注文をERP(管家婆)システムにプッシュして処理する機能をサポート&lt;/li&gt;
&lt;li&gt;デュアルモード取引：
&lt;ul&gt;
&lt;li&gt;オンライン注文、宅配便発送&lt;/li&gt;
&lt;li&gt;オンライン注文、店舗受け取り/配達員による配送&lt;/li&gt;
&lt;/ul&gt;
&lt;/li&gt;
&lt;/ul&gt;
&lt;h3 id=&#34;システムプレビュー&#34;&gt;システムプレビュー&lt;/h3&gt;
&lt;h4 id=&#34;バックエンド管理画面&#34;&gt;バックエンド管理画面&lt;/h4&gt;
&lt;p&gt;&lt;img loading=&#34;lazy&#34; src=&#34;https://gh-proxy.com/github.com/iAJue/MoeJueBlogPic/blob/master/Images/2025/04/17/QQ20250417-111108_04_17_2025.jpg&#34;&gt; &lt;img loading=&#34;lazy&#34; src=&#34;https://gh-proxy.com/github.com/iAJue/MoeJueBlogPic/blob/master/Images/2025/04/17/QQ20250417-111207_04_17_2025.jpg&#34;&gt; &lt;img loading=&#34;lazy&#34; src=&#34;https://gh-proxy.com/github.com/iAJue/MoeJueBlogPic/blob/master/Images/2025/04/17/QQ20250417-111236_04_17_2025.jpg&#34;&gt; &lt;img loading=&#34;lazy&#34; src=&#34;https://gh-proxy.com/github.com/iAJue/MoeJueBlogPic/blob/master/Images/2025/04/17/QQ20250417-111316_04_17_2025.jpg&#34;&gt; &lt;img loading=&#34;lazy&#34; src=&#34;https://gh-proxy.com/github.com/iAJue/MoeJueBlogPic/blob/master/Images/2025/04/17/QQ20250417-111333_04_17_2025.jpg&#34;&gt; &lt;img loading=&#34;lazy&#34; src=&#34;https://gh-proxy.com/github.com/iAJue/MoeJueBlogPic/blob/master/Images/2025/04/17/QQ20250417-111348_04_17_2025.jpg&#34;&gt; &lt;img loading=&#34;lazy&#34; src=&#34;https://gh-proxy.com/github.com/iAJue/MoeJueBlogPic/blob/master/Images/2025/04/17/QQ20250417-111425_04_17_2025.jpg&#34;&gt; &lt;img loading=&#34;lazy&#34; src=&#34;https://gh-proxy.com/github.com/iAJue/MoeJueBlogPic/blob/master/Images/2025/04/17/QQ20250417-114400_04_17_2025.jpg&#34;&gt;&lt;/p&gt;
&lt;h4 id=&#34;ミニプログラム画面&#34;&gt;ミニプログラム画面&lt;/h4&gt;
&lt;p&gt;&lt;img loading=&#34;lazy&#34; src=&#34;https://gh-proxy.com/github.com/iAJue/MoeJueBlogPic/blob/master/Images/2025/04/17/QQ20250417-115015_04_17_2025.jpg&#34;&gt; &lt;img loading=&#34;lazy&#34; src=&#34;https://gh-proxy.com/github.com/iAJue/MoeJueBlogPic/blob/master/Images/2025/04/17/QQ20250417-115348_04_17_2025.jpg&#34;&gt; &lt;img loading=&#34;lazy&#34; src=&#34;https://gh-proxy.com/github.com/iAJue/MoeJueBlogPic/blob/master/Images/2025/04/17/Screenshot_2025-04-17-11-51-48-260_com.tencent.mm_04_17_2025.jpg&#34;&gt; &lt;img loading=&#34;lazy&#34; src=&#34;https://gh-proxy.com/github.com/iAJue/MoeJueBlogPic/blob/master/Images/2025/04/17/Screenshot_2025-04-17-11-51-41-636_com.tencent.mm_04_17_2025.jpg&#34;&gt; &lt;img loading=&#34;lazy&#34; src=&#34;https://gh-proxy.com/github.com/iAJue/MoeJueBlogPic/blob/master/Images/2025/04/17/Screenshot_2025-04-17-11-51-32-607_com.tencent.mm_04_17_2025.jpg&#34;&gt; &lt;img loading=&#34;lazy&#34; src=&#34;https://gh-proxy.com/github.com/iAJue/MoeJueBlogPic/blob/master/Images/2025/04/17/Screenshot_2025-04-17-11-51-28-173_com.tencent.mm_04_17_2025.jpg&#34;&gt; &lt;img loading=&#34;lazy&#34; src=&#34;https://gh-proxy.com/github.com/iAJue/MoeJueBlogPic/blob/master/Images/2025/04/17/Screenshot_2025-04-17-11-51-14-865_com.tencent.mm_04_17_2025.jpg&#34;&gt; &lt;img loading=&#34;lazy&#34; src=&#34;https://gh-proxy.com/github.com/iAJue/MoeJueBlogPic/blob/master/Images/2025/04/17/QQ20250417-115521_04_17_2025.jpg&#34;&gt; &lt;img loading=&#34;lazy&#34; src=&#34;https://gh-proxy.com/github.com/iAJue/MoeJueBlogPic/blob/master/Images/2025/04/17/QQ20250417-115423_04_17_2025.jpg&#34;&gt; &lt;img loading=&#34;lazy&#34; src=&#34;https://gh-proxy.com/github.com/iAJue/MoeJueBlogPic/blob/master/Images/2025/04/17/QQ20250417-115405_04_17_2025.jpg&#34;&gt;&lt;/p&gt;
&lt;h3 id=&#34;バージョン説明&#34;&gt;バージョン説明&lt;/h3&gt;
&lt;p&gt;現在のバージョンはV1.0版です。一部の画面は将来の計画のために予約されており、実際のニーズに基づいて継続的に更新・改善されます。正式リリース版がなく、ミニプログラムの運用も開始していないため、オンラインでデモできるバージョンはありません。現在のプログラムはV1.0の初期バージョンであり、一部の画面は事前に計画されて予約されています。今後、ニーズに応じて更新されます。&lt;/p&gt;
&lt;h3 id=&#34;購入について&#34;&gt;購入について&lt;/h3&gt;
&lt;ul&gt;
&lt;li&gt;価格：188元 (バージョン更新後、状況に応じて価格が調整される場合があります。実際の価格をご確認ください)&lt;/li&gt;
&lt;li&gt;内容：完全なソースコード（モバイル版とバックエンドを含む、暗号化なし、ライセンスなし）&lt;/li&gt;
&lt;li&gt;紹介リベート：友人の購入を紹介すると20%のリベートを獲得できます&lt;/li&gt;
&lt;li&gt;更新サービス：生涯無料更新&lt;/li&gt;
&lt;li&gt;利用規約：無断での転売は禁止します。違反した場合、更新サービスは停止されます。&lt;/li&gt;
&lt;li&gt;開発サポート：ソースコードには詳細なコメントが含まれており、二次開発に便利です。&lt;/li&gt;
&lt;li&gt;プロジェクトホスティング：コードはGitHubでホストされており、更新履歴は完全かつ透明です。&lt;/li&gt;
&lt;li&gt;マルチプラットフォームサポート：他のクライアントはご自身でコンパイルする必要があります。WeChatミニプログラム環境をベースに開発されています。&lt;/li&gt;
&lt;/ul&gt;
&lt;h3 id=&#34;連絡先&#34;&gt;連絡先&lt;/h3&gt;
&lt;ul&gt;
&lt;li&gt;QQ交流グループ：&lt;a href=&#34;https://qm.qq.com/q/Fhqk6HKUaQ&#34;&gt;参加はこちら&lt;/a&gt;&lt;/li&gt;
&lt;li&gt;個人のQQリンクがないため、グループ参加後、グループオーナーに@メンションして購入についてお問い合わせください。&lt;/li&gt;
&lt;li&gt;プロジェクトが売れ残っています。阿珏酱を助けてください。&lt;/li&gt;
&lt;/ul&gt;
&lt;h3 id=&#34;オンラインデモ&#34;&gt;オンラインデモ&lt;/h3&gt;
&lt;ul&gt;
&lt;li&gt;&lt;a href=&#34;https://v.douyin.com/3l90gHoAf0A/&#34;&gt;WeChatミニプログラム版デモ動画&lt;/a&gt;&lt;/li&gt;
&lt;li&gt;バックエンドのデモ環境についてはお問い合わせください。&lt;/li&gt;
&lt;li&gt;WeChatミニプログラムの体験権限追加についてはお問い合わせください。&lt;/li&gt;
&lt;/ul&gt;</description>
    </item>
    <item>
      <title>オープンソースでシンプルかつスタイリッシュな、酷狗のサードパーティ製クライアント V1.0.0 Beta</title>
      <link>https://en.moejue.cn/ja/posts/225/</link>
      <pubDate>Sun, 03 Nov 2024 12:48:04 +0000</pubDate>
      <guid>https://en.moejue.cn/ja/posts/225/</guid>
      <description>&lt;p&gt;&lt;img alt=&#34;Logo&#34; loading=&#34;lazy&#34; src=&#34;https://github.com/iAJue/MoeKoeMusic/raw/main/images/logo.png&#34;&gt;&lt;/p&gt;
&lt;h2 id=&#34;moekoe-music&#34;&gt;MoeKoe Music&lt;/h2&gt;
&lt;p&gt;オープンソースでシンプル、見た目も美しいKuGouのサードパーティクライアント&lt;br&gt;
&lt;a href=&#34;https://github.com/iAJue/MoeKoeMusic/&#34;&gt;&lt;strong&gt;🌎 GitHubリポジトリ&lt;/strong&gt;&lt;/a&gt;  |  &lt;a href=&#34;https://github.com/iAJue/MoeKoeMusic/releases&#34;&gt;&lt;strong&gt;📦️ インストーラーをダウンロード&lt;/strong&gt;&lt;/a&gt;  |  &lt;a href=&#34;https://MoeJue.cn&#34;&gt;&lt;strong&gt;💬 ブログを訪問&lt;/strong&gt;&lt;/a&gt;&lt;/p&gt;
&lt;p&gt;&lt;img alt=&#34;images&#34; loading=&#34;lazy&#34; src=&#34;https://github.com/iAJue/MoeKoeMusic/raw/main/images/5.png&#34;&gt;&lt;/p&gt;
&lt;h2 id=&#34;はじめに&#34;&gt;はじめに&lt;/h2&gt;
&lt;p&gt;10年ほど前、ウェブ版QQを使っていた頃からKuGou Musicを使い始めました（もう10年来のファンです）。なので、この数年で集めた曲はすべてそこにあります。その後、NetEase Cloud MusicやQQ Musicも試してみましたが、KuGouのプレイリストをインポートしようとしても、結果は芳しくありませんでした。私が聴くのは主に日本のアニメのOPで、多くの曲が見つかりませんでした。&lt;/p&gt;
&lt;p&gt;結局、KuGouに戻ってきました。しかし、Mac版のKuGouは時々再生できないことがありました。インターフェースはシンプルですが、それはそれで良い点です。ネットユーザーの勧めで、今はKuGouの&lt;a href=&#34;https://t1.kugou.com/d2tBza3CSV2&#34;&gt;コンセプト版&lt;/a&gt;で音楽を聴いています。これは市場で数少ない、VIP曲を無料で聴ける音楽プレイヤーで、強くお勧めします。&lt;/p&gt;
&lt;p&gt;私の自己紹介ページで、特に日本のアニメのOPを聴くのが大好きだと書きました。それをどう証明するか？（以前のウェブ版プレイリストも長年放置されていました）そうだ、自分で音楽プレイヤーを開発しよう、と。&lt;/p&gt;
&lt;h2 id=&#34;-特徴&#34;&gt;✨ 特徴&lt;/h2&gt;
&lt;ul&gt;
&lt;li&gt;✅ Vue.js ファミリーを使用して開発&lt;/li&gt;
&lt;li&gt;🔴 KuGouアカウントでのログイン（QRコード/携帯電話/アカウントでのログイン）&lt;/li&gt;
&lt;li&gt;📃 歌詞表示をサポート&lt;/li&gt;
&lt;li&gt;📻 毎日のおすすめ曲&lt;/li&gt;
&lt;li&gt;🚫🤝 ソーシャル機能一切なし&lt;/li&gt;
&lt;li&gt;🔗 公式サーバーに直接接続、サードパーティAPIは一切使用しません&lt;/li&gt;
&lt;li&gt;✔️ 毎日VIPを自動で受け取り、ログインするだけでVIPに&lt;/li&gt;
&lt;li&gt;🎨 テーマカラーの切り替え&lt;/li&gt;
&lt;li&gt;👋 起動時の挨拶メッセージ&lt;/li&gt;
&lt;li&gt;⚙️ マルチプラットフォーム対応&lt;/li&gt;
&lt;li&gt;🛠 さらに多くの機能を開発中&lt;/li&gt;
&lt;/ul&gt;
&lt;h2 id=&#34;todo-list&#34;&gt;Todo List&lt;/h2&gt;
&lt;ul&gt;
&lt;li&gt;[ ] 📺 MV再生をサポート&lt;/li&gt;
&lt;li&gt;[ ] 🌚 Light/Dark Modeの自動切り替え&lt;/li&gt;
&lt;li&gt;[ ] 👆 Touch Barをサポート&lt;/li&gt;
&lt;li&gt;[ ] 🖥️ PWAをサポート、Chrome/Edgeのアドレスバー右側の ➕ をクリックしてPCにインストール可能&lt;/li&gt;
&lt;li&gt;[ ] 🟥 Last.fm Scrobbleをサポート&lt;/li&gt;
&lt;li&gt;[ ] 🎧 Mprisをサポート&lt;/li&gt;
&lt;li&gt;[ ] ⌨️ カスタムショートカットキーとグローバルショートカットキー&lt;/li&gt;
&lt;li&gt;[ ] 🤟 多言語対応&lt;/li&gt;
&lt;li&gt;[ ] 📻 デスクトップ歌詞&lt;/li&gt;
&lt;li&gt;[ ] ⚙️ システムアーキテクチャの最適化&lt;/li&gt;
&lt;li&gt;[ ] 🎶 曲、プレイリスト/お気に入り、削除&lt;/li&gt;
&lt;/ul&gt;
&lt;h2 id=&#34;-インストール&#34;&gt;📦️ インストール&lt;/h2&gt;
&lt;p&gt;本プロジェクトの &lt;a href=&#34;https://github.com/iAJue/MoeKoeMusic/releases&#34;&gt;Releases&lt;/a&gt; ページにアクセスしてインストーラーをダウンロードしてください。&lt;/p&gt;</description>
    </item>
    <item>
      <title>マルチプラットフォーム記事同期ブラウザ拡張機能 - ArticleSync</title>
      <link>https://en.moejue.cn/ja/posts/218/</link>
      <pubDate>Wed, 16 Oct 2024 11:02:49 +0000</pubDate>
      <guid>https://en.moejue.cn/ja/posts/218/</guid>
      <description>&lt;h2 id=&#34;articlesync---マルチプラットフォーム記事同期プラグイン&#34;&gt;ArticleSync - マルチプラットフォーム記事同期プラグイン&lt;/h2&gt;
&lt;p&gt;ArticleSyncは、ユーザーが複数のソーシャルプラットフォームに記事を簡単に同期・公開できるブラウザ拡張機能です。ローカルの下書きから、知乎（Zhihu）やBilibiliなどの主要プラットフォームに記事を公開することをサポートしています。これにより、異なるソーシャルメディアプラットフォーム間で記事を同期する作業が、シンプルかつ効率的になるワンストップソリューションを提供します。&lt;/p&gt;
&lt;p&gt;ブラウザ拡張機能の仕組みに基づき、ローカルでログインしているアカウントを自動的に検出し、アカウント情報の漏洩や環境の異常といったリスクを防ぎます。&lt;/p&gt;
&lt;p&gt;Chrome Manifest V3ブラウザ拡張機能の標準に基づいて開発されており、カーネルのバージョン要件にご注意ください。&lt;/p&gt;
&lt;h3 id=&#34;背景&#34;&gt;背景&lt;/h3&gt;
&lt;p&gt;ご存知の通り、私は最近、いくつかのブログプラットフォームと多くのソーシャルサイトを新たに使い始めました。もし、それらすべてで活発に更新を続けたいと思ったらどうすればいいでしょうか。（私がまだ生きていることを証明するために）ついでに、ワンクリックで記事を転載することもできます。&lt;/p&gt;
&lt;p&gt;私が最も頻繁に更新するのは自分の小さなサイトですが、他のプラットフォームはたまにしか更新しません。しかし、毎回手動で投稿するのは面倒です。そこで、ローカルでログインしているアカウントを自動検出し、自動で投稿してくれるプラグインが作れないかと考えました。&lt;/p&gt;
&lt;p&gt;「自分のことは自分でやる」ということわざの通り、数日間いじくり回して、なんとか使えるものができました。残りの部分は時間があるときに更新します。お金をくれるなら話は別ですが。&lt;/p&gt;
&lt;p&gt;このプラグインにはまだ多くの未完成な部分があり、本番環境で複数のプラットフォームでのテストも行っていません。エラーが発生するのはごく普通のことですので、その際はIssueを提出するか、自分で修正してPRを送ってください。てへぺろ〜&lt;/p&gt;
&lt;p&gt;話の邪魔にならないように、スクリーンショットは最後に載せておきました。&lt;/p&gt;
&lt;p&gt;それと、オープンソースは大変なので、スターを付けてくれると嬉しいです。へへへ〜&lt;/p&gt;
&lt;p&gt;本当は、私のコミュニティプラットフォームを自動でフォローするような、個人的な機能を追加しようかとも思いました。&lt;/p&gt;
&lt;h3 id=&#34;機能と特徴&#34;&gt;機能と特徴&lt;/h3&gt;
&lt;ul&gt;
&lt;li&gt;&lt;strong&gt;マルチプラットフォーム対応&lt;/strong&gt;：知乎（Zhihu）、Bilibiliなどの主要プラットフォームや、自作のオープンソースCMSシステムをサポートしています。&lt;/li&gt;
&lt;li&gt;&lt;strong&gt;ステータス追跡&lt;/strong&gt;：プラグインのインターフェースで記事の同期状況を確認できます。&lt;/li&gt;
&lt;li&gt;&lt;strong&gt;アカウント管理&lt;/strong&gt;：プラグインに連携されている各プラットフォームのアカウント情報を確認できます。&lt;/li&gt;
&lt;li&gt;&lt;strong&gt;高い拡張性&lt;/strong&gt;：開発者はアダプターパターンを通じて、簡単により多くのプラットフォームに拡張できます。&lt;/li&gt;
&lt;li&gt;&lt;strong&gt;安全性と信頼性&lt;/strong&gt;：ブラウザ拡張機能の仕組みに基づいているため、アカウントの安全性を確保し、情報漏洩などのリスクを回避します。&lt;/li&gt;
&lt;/ul&gt;
&lt;h3 id=&#34;todoリスト&#34;&gt;Todoリスト&lt;/h3&gt;
&lt;ul&gt;
&lt;li&gt;[ ] 独立した記事エディタ&lt;/li&gt;
&lt;li&gt;[ ] 画像のワンクリック同期&lt;/li&gt;
&lt;li&gt;[x] MarkdownとHTMLの相互変換&lt;/li&gt;
&lt;li&gt;[ ] サードパーティの画像ホスティングサービス&lt;/li&gt;
&lt;li&gt;[ ] 複数アカウント管理&lt;/li&gt;
&lt;li&gt;[ ] マルチOSクライアントバージョン&lt;/li&gt;
&lt;li&gt;[ ] ワンクリックAI要約&lt;/li&gt;
&lt;li&gt;[ ] 動画の同期&lt;/li&gt;
&lt;li&gt;[ ] タグ、カテゴリのサポート&lt;/li&gt;
&lt;li&gt;[ ] より親切なエラーハンドリング&lt;/li&gt;
&lt;li&gt;[ ] より多くのプラットフォームへの対応&lt;/li&gt;
&lt;/ul&gt;
&lt;h3 id=&#34;対応プラットフォーム&#34;&gt;対応プラットフォーム&lt;/h3&gt;
&lt;table&gt;
  &lt;thead&gt;
      &lt;tr&gt;
          &lt;th style=&#34;text-align: left&#34;&gt;メディア&lt;/th&gt;
          &lt;th style=&#34;text-align: left&#34;&gt;カテゴリ&lt;/th&gt;
          &lt;th style=&#34;text-align: left&#34;&gt;ステータス&lt;/th&gt;
          &lt;th style=&#34;text-align: left&#34;&gt;URL&lt;/th&gt;
          &lt;th style=&#34;text-align: left&#34;&gt;対応形式&lt;/th&gt;
          &lt;th style=&#34;text-align: left&#34;&gt;更新日時&lt;/th&gt;
      &lt;/tr&gt;
  &lt;/thead&gt;
  &lt;tbody&gt;
      &lt;tr&gt;
          &lt;td style=&#34;text-align: left&#34;&gt;Bilibili (哔哩哔哩)&lt;/td&gt;
          &lt;td style=&#34;text-align: left&#34;&gt;主要セルフメディア&lt;/td&gt;
          &lt;td style=&#34;text-align: left&#34;&gt;対応済み&lt;/td&gt;
          &lt;td style=&#34;text-align: left&#34;&gt;&lt;a href=&#34;https://bilibili.com/&#34;&gt;https://bilibili.com/&lt;/a&gt;&lt;/td&gt;
          &lt;td style=&#34;text-align: left&#34;&gt;HTML&lt;/td&gt;
          &lt;td style=&#34;text-align: left&#34;&gt;2024/10/13&lt;/td&gt;
      &lt;/tr&gt;
      &lt;tr&gt;
          &lt;td style=&#34;text-align: left&#34;&gt;知乎 (Zhihu)&lt;/td&gt;
          &lt;td style=&#34;text-align: left&#34;&gt;主要セルフメディア&lt;/td&gt;
          &lt;td style=&#34;text-align: left&#34;&gt;対応済み&lt;/td&gt;
          &lt;td style=&#34;text-align: left&#34;&gt;&lt;a href=&#34;https://www.zhihu.com/&#34;&gt;https://www.zhihu.com/&lt;/a&gt;&lt;/td&gt;
          &lt;td style=&#34;text-align: left&#34;&gt;HTML&lt;/td&gt;
          &lt;td style=&#34;text-align: left&#34;&gt;2024/10/13&lt;/td&gt;
      &lt;/tr&gt;
      &lt;tr&gt;
          &lt;td style=&#34;text-align: left&#34;&gt;博客园 (Cnblogs)&lt;/td&gt;
          &lt;td style=&#34;text-align: left&#34;&gt;ブログ&lt;/td&gt;
          &lt;td style=&#34;text-align: left&#34;&gt;対応済み&lt;/td&gt;
          &lt;td style=&#34;text-align: left&#34;&gt;&lt;a href=&#34;https://cnblogs.com/&#34;&gt;https://cnblogs.com/&lt;/a&gt;&lt;/td&gt;
          &lt;td style=&#34;text-align: left&#34;&gt;HTML&lt;/td&gt;
          &lt;td style=&#34;text-align: left&#34;&gt;2024/10/14&lt;/td&gt;
      &lt;/tr&gt;
      &lt;tr&gt;
          &lt;td style=&#34;text-align: left&#34;&gt;新浪头条 (Sina Headline)&lt;/td&gt;
          &lt;td style=&#34;text-align: left&#34;&gt;主要セルフメディア&lt;/td&gt;
          &lt;td style=&#34;text-align: left&#34;&gt;対応済み&lt;/td&gt;
          &lt;td style=&#34;text-align: left&#34;&gt;&lt;a href=&#34;https://weibo.com/&#34;&gt;https://weibo.com/&lt;/a&gt;&lt;/td&gt;
          &lt;td style=&#34;text-align: left&#34;&gt;HTML&lt;/td&gt;
          &lt;td style=&#34;text-align: left&#34;&gt;2024/10/14&lt;/td&gt;
      &lt;/tr&gt;
      &lt;tr&gt;
          &lt;td style=&#34;text-align: left&#34;&gt;Emlog&lt;/td&gt;
          &lt;td style=&#34;text-align: left&#34;&gt;オープンソースCMS&lt;/td&gt;
          &lt;td style=&#34;text-align: left&#34;&gt;対応済み&lt;/td&gt;
          &lt;td style=&#34;text-align: left&#34;&gt;&lt;a href=&#34;https://www.emlog.net/&#34;&gt;https://www.emlog.net/&lt;/a&gt;&lt;/td&gt;
          &lt;td style=&#34;text-align: left&#34;&gt;HTML&lt;/td&gt;
          &lt;td style=&#34;text-align: left&#34;&gt;2024/10/14&lt;/td&gt;
      &lt;/tr&gt;
      &lt;tr&gt;
          &lt;td style=&#34;text-align: left&#34;&gt;WordPress&lt;/td&gt;
          &lt;td style=&#34;text-align: left&#34;&gt;オープンソースCMS&lt;/td&gt;
          &lt;td style=&#34;text-align: left&#34;&gt;対応済み&lt;/td&gt;
          &lt;td style=&#34;text-align: left&#34;&gt;&lt;a href=&#34;https://cn.wordpress.org/&#34;&gt;https://cn.wordpress.org/&lt;/a&gt;&lt;/td&gt;
          &lt;td style=&#34;text-align: left&#34;&gt;HTML,Markdown&lt;/td&gt;
          &lt;td style=&#34;text-align: left&#34;&gt;2024/10/14&lt;/td&gt;
      &lt;/tr&gt;
      &lt;tr&gt;
          &lt;td style=&#34;text-align: left&#34;&gt;Discuz!&lt;/td&gt;
          &lt;td style=&#34;text-align: left&#34;&gt;オープンソースCMS&lt;/td&gt;
          &lt;td style=&#34;text-align: left&#34;&gt;対応済み&lt;/td&gt;
          &lt;td style=&#34;text-align: left&#34;&gt;&lt;a href=&#34;https://www.discuz.vip/&#34;&gt;https://www.discuz.vip/&lt;/a&gt;&lt;/td&gt;
          &lt;td style=&#34;text-align: left&#34;&gt;Markdown,Text&lt;/td&gt;
          &lt;td style=&#34;text-align: left&#34;&gt;2024/10/15&lt;/td&gt;
      &lt;/tr&gt;
  &lt;/tbody&gt;
&lt;/table&gt;
&lt;h3 id=&#34;インストール手順&#34;&gt;インストール手順&lt;/h3&gt;
&lt;ol&gt;
&lt;li&gt;
&lt;p&gt;リポジトリをローカルにクローンします：&lt;/p&gt;</description>
    </item>
    <item>
      <title>敗者復活戦に勝って、生き返った</title>
      <link>https://en.moejue.cn/ja/posts/206/</link>
      <pubDate>Thu, 03 Oct 2024 02:48:02 +0000</pubDate>
      <guid>https://en.moejue.cn/ja/posts/206/</guid>
      <description>&lt;h3 id=&#34;近況&#34;&gt;近況&lt;/h3&gt;
&lt;p&gt;前回の雑談からもう2ヶ月以上も経ってしまいました。そろそろ自分の考えを整理する時が来たようです。前回は色々と感慨を述べたきり音沙汰がなかったので、少し急ぎすぎたかもしれません。その後の作業が追いつかなくなってしまいました。&lt;/p&gt;
&lt;p&gt;また国慶節の季節がやってきました。やはり私の国慶節は「独身の日（ダブルイレブン）」のようなものです。以前所有していた3つのドメイン（52ecy.cn, moeins.cn, moeins.com）は、復活戦には勝ったものの、装備がなくなってしまいました。&lt;/p&gt;
&lt;p&gt;そのため、ドメインを新規購入するしかありませんでした。同時にもブログを復旧させました。やはり自分でいじりたいのでしょう。博客园（cnblogs）に間借りするのは、どうも居心地が悪く感じます。&lt;/p&gt;
&lt;p&gt;以前からずっと使っていたemlogですが、この機会に思い切ってシステムをWordPressに移行し、同時に新しいテーマに切り替えました。このテーマは&lt;a href=&#34;https://www.boxmoe.com/&#34;&gt;专收爆米花&lt;/a&gt;さんが21年頃にリリースしたもので、当時locで見かけてすぐにstarを付け、私のGitHubで4年間眠っていました&lt;a href=&#34;https://github.com/iAJue/lolimeow&#34;&gt;lolimeow&lt;/a&gt;。当時はずっとemlogを使っていたので、いじるのが面倒だったのです。この機会に乗じて、徹底的にやろうと決め、データの移行やテーマの調整など、かなりの手間をかけました。&lt;/p&gt;
&lt;p&gt;作者の方がずっとテーマの更新を積極的に進めてくれていたおかげで、使用中に大きな問題はありませんでした。しかし、私が以前使っていたシステムの機能がいくつか欠けていたので、私もこのテーマを更新し、元のリポジトリにプルリクエストを送りました。上に貼ったGitHubのリンクは私が更新した後のものです。&lt;img loading=&#34;lazy&#34; src=&#34;https://image.baidu.com/search/down?url=https://tva1.sinaimg.cn/large/78350c19ly8hu90no7xm8j20w414kdue.jpg&#34;&gt; 最も面倒だったデータ移行の部分ですが、ネットで長いこと探し回ってもexe版しか見つかりませんでした。exe版はなんとなく不安な感じがする上に、私は今Macを使っているので、直接実行することもできません。「ないなら自分で作ればいい」ということで、時間をかけて移行スクリプトを自作するしかありませんでした。GitHubのアドレスは記事の最後に載せてあります。emlogのデータをWordPressに完璧に移行できます。さすが俺！&lt;img loading=&#34;lazy&#34; src=&#34;https://image.baidu.com/search/down?url=https://tva1.sinaimg.cn/large/78350c19ly8hu86bsccndj21hc0u0gr1.jpg&#34;&gt;&lt;/p&gt;
&lt;p&gt;画像はこれまで通り、一部はバックアップとして七牛云（Qiniu Cloud）に、もう一部は新浪图床（Sina Image Hosting）に保存しています。移行してみると、市場には私に適した使いやすい七牛云プラグインがなかったので、また自分で一つ作りました。&lt;img loading=&#34;lazy&#34; src=&#34;https://image.baidu.com/search/down?url=https://tva1.sinaimg.cn/large/78350c19ly8hu8aervippj20z608i0ws.jpg&#34;&gt; &lt;img loading=&#34;lazy&#34; src=&#34;https://image.baidu.com/search/down?url=https://tva1.sinaimg.cn/large/78350c19ly8hu8aexj66gj20zw12yk01.jpg&#34;&gt;&lt;/p&gt;
&lt;h3 id=&#34;新ドメイン&#34;&gt;新ドメイン&lt;/h3&gt;
&lt;p&gt;あまり気は進みませんでしたが、またドメインを変更するしかありませんでした。以前のドメインは他人の肥やしになってしまいました。萌音シリーズ：MoeKot.cn。「萌音ノート」「萌音カード」「萌音コミュニティ」「萌音ストア」などを含む萌音シリーズは、今後このドメインの下に置かれます。メインサイトシリーズ：MoeJue.cn。これは私のメインサイトで、ブログやシリーズに属さないプロジェクトなどがこのドメインの下に置かれます。&lt;/p&gt;
&lt;h4 id=&#34;解説&#34;&gt;解説&lt;/h4&gt;
&lt;p&gt;Moe: 日本語の「萌え」の読み方で、ローマ字表記です。中国語では一般的に「萌」と訳されます。
Kot: 日本語の「声（こえ）」を意味する言葉で、ローマ字表記です。
Jue: 阿珏（A Jue）ちゃんの簡単な音訳です。&lt;/p&gt;
&lt;h3 id=&#34;ブログ&#34;&gt;ブログ&lt;/h3&gt;
&lt;p&gt;私はとても昔を懐かしむ情に厚い人間なので、以前のブログもすべて残してあります。&lt;a href=&#34;http://xlog.moejue.cn/&#34;&gt;Xlog&lt;/a&gt; &lt;a href=&#34;https://www.cnblogs.com/Ajue&#34;&gt;cnblogs&lt;/a&gt; &lt;a href=&#34;https://log.MoeJue.cn&#34;&gt;emlog&lt;/a&gt; &lt;a href=&#34;https://blog.moejue.cn&#34;&gt;Blog&lt;/a&gt; 関連サイトのドメインも移行しましたが、すべてをリストアップするのはやめておきます。もちろん、一部のリンクが完全に置換されていない可能性もあります。&lt;/p&gt;
&lt;p&gt;すべてのデータは元のままで、誰一人のデータも欠けていません。ブログの登録ユーザーのデータさえも一緒に移行したので、新しいシステムで直接ログインできます。パスワードも同じです。&lt;/p&gt;
&lt;h5 id=&#34;ぜひstarを付けてください&#34;&gt;ぜひstarを付けてください！&lt;/h5&gt;
&lt;p&gt;使い方もREADME.mdに書いておきました。何か問題があれば、直接issueを立ててください。&lt;/p&gt;
&lt;h4 id=&#34;emlogからwordpressへの移行スクリプト&#34;&gt;&lt;a href=&#34;https://github.com/iAJue/migrate_emlog_to_wp&#34;&gt;emlogからWordPressへの移行スクリプト&lt;/a&gt;&lt;/h4&gt;
&lt;p&gt;私のブログは間もなくTencent Cloud開発者コミュニティにも同期される予定です。皆さんのご参加をお待ちしています：&lt;a href=&#34;https://cloud.tencent.com/developer/support-plan?invite_code=15kxzzid10tgx&#34;&gt;https://cloud.tencent.com/developer/support-plan?invite_code=15kxzzid10tgx&lt;/a&gt;&lt;/p&gt;</description>
    </item>
    <item>
      <title>転生：ECサイトを構築する - 萌音ECサイトV1.0リリース</title>
      <link>https://en.moejue.cn/ja/posts/203/</link>
      <pubDate>Wed, 02 Oct 2024 06:17:50 +0000</pubDate>
      <guid>https://en.moejue.cn/ja/posts/203/</guid>
      <description>&lt;p&gt;萌音シリーズのN+1番目のプロジェクトが来ましたね。これも実は数年間放置していたプロジェクトで、今回ようやく完成させることができました。&lt;/p&gt;
&lt;h5 id=&#34;まずはプロジェクトアドレス-httpsmoekoecn&#34;&gt;まずはプロジェクトアドレス: &lt;a href=&#34;https://MoeKoe.cn&#34;&gt;https://MoeKoe.cn&lt;/a&gt;&lt;/h5&gt;
&lt;h4 id=&#34;なぜ私はプロジェクトを作り続けているのか&#34;&gt;なぜ私はプロジェクトを作り続けているのか？&lt;/h4&gt;
&lt;p&gt;この質問はとても面白いですね。なぜ様々なプロジェクトを、しかもお金にならないものばかり作り続けているのか。私の以前のプロジェクトに触れたことのある方はご存知でしょうが、私はどんなプロジェクトも「自分が使う」という原則に基づいて制作しています。もちろん今回も例外ではありません。ずっと、どこかのプラットフォームで、持っているけれど使わず、捨てるには惜しい小物たちを売りたいと思っていました。同時に、面白くて楽しい製品を皆さんと共有したいとも思っています（将来的には私のIP製品も加わるかもしれません）。「最高の出来事や物を、最高のあなたと共有したい」という思いもありますし、「他人が持っているなら私も持つべきだ」という原則に基づいて、私も持たなければなりません。&lt;/p&gt;
&lt;p&gt;もし私がただ小物を売りたいだけなら、なぜ直接淘宝や闲鱼のようなプラットフォームを使わないのでしょうか。一歩譲って、これらのプラットフォームを使わないとしても、既存のECシステムを自分で構築することもできます。今や市場には成熟していて使いやすいシステムが山ほどあります。なぜわざわざ自分で開発する必要があるのでしょうか？&lt;/p&gt;
&lt;p&gt;一言で言えば、好きだからです。これは私の趣味で、創造することが好きで、面白いものやことをするのが好きなんです。私はただ生きているだけの凡人ではなく、すごくて面白い人間になりたい。もっと多くの面白い魂と出会いたい。「すごい」という私の定義は、技術がどれほど優れているか、お金をどれほど稼ぐかということではありません。挫折や困難に直面したときでも、笑顔で立ち向かい、楽観的であり続け、初心を忘れない人。そのような人を、私は「すごい人」と呼びたいのです。&lt;/p&gt;
&lt;p&gt;新しいプロジェクトを発表する記事なのに、またしても口語体のブログになってしまいました、ハハハ。&lt;/p&gt;
&lt;h3 id=&#34;プロジェクト紹介&#34;&gt;プロジェクト紹介&lt;/h3&gt;
&lt;p&gt;最近何をしているか？ピンクで可愛らしいもの、つまり二次元少女萌え系スタイルの魔法少女ECサイトを作っています。&lt;/p&gt;
&lt;blockquote&gt;
&lt;p&gt;魔法少女のファンタジー世界へようこそ！二次元の無限の可能性を探る冒険の旅を始めましょう！これは二次元愛好家のために特別に作られたオンラインECサイトです。ここでは、最も輝く魔法のアイテム、最もキュートな変身コスチューム、そして豊富で多様な二次元関連商品を見つけることができます。可愛い萌えグッズに夢中な方も、クールなコレクターズアイテムがお好きな方も、二次元へのすべての愛と期待をここで満たすことができます！&lt;/p&gt;
&lt;/blockquote&gt;
&lt;p&gt;URLをクリックすると、目が覚めるような（ピンクの）感覚を覚えるでしょう。そうです、これこそ私が求めていたスタイルです。ピンクで可愛らしく、乙女心満載で、カワイイ感じ。これこそが私の個性を際立たせるのです。&lt;img loading=&#34;lazy&#34; src=&#34;https://image.baidu.com/search/down?url=https://tva1.sinaimg.cn/large/78350c19ly8hu80pi6l1vj22bm1g2kjp.jpg&#34;&gt;&lt;/p&gt;
&lt;h3 id=&#34;技術スタック&#34;&gt;技術スタック&lt;/h3&gt;
&lt;ul&gt;
&lt;li&gt;Vue.js3&lt;/li&gt;
&lt;li&gt;Vite&lt;/li&gt;
&lt;li&gt;Pinia&lt;/li&gt;
&lt;li&gt;Axios&lt;/li&gt;
&lt;li&gt;Node.js&lt;/li&gt;
&lt;li&gt;Express&lt;/li&gt;
&lt;li&gt;Mysql&lt;/li&gt;
&lt;li&gt;Nginx&lt;/li&gt;
&lt;li&gt;フロントエンドとバックエンドの分離&lt;/li&gt;
&lt;li&gt;MySQLスレッドプール&lt;/li&gt;
&lt;/ul&gt;
&lt;p&gt;Vue.jsのフルスタックは本当に素晴らしいですね。ネイティブで書く手間が省けます。現在、国際化プラグイン（i18n）はこのバージョンにはまだ搭載されていません。市販のUIライブラリがこのプロジェクトの私の位置付けや個性に直接合致しないため、既存のUIライブラリは使用せず、すべて自分で手書きしました。&lt;/p&gt;
&lt;p&gt;&lt;img loading=&#34;lazy&#34; src=&#34;https://image.baidu.com/search/down?url=https://tva1.sinaimg.cn/large/78350c19ly8hu80vhmhh0j21ys1fqqv7.jpg&#34;&gt;&lt;/p&gt;
&lt;h3 id=&#34;紹介&#34;&gt;紹介:&lt;/h3&gt;
&lt;ul&gt;
&lt;li&gt;仮想通貨USDTに対応（ウォレットアドレスを入力するだけで、自動で着金を監視。外部プログラム不要。監視システムは新規注文があると自動起動し、30分間新規注文がないと自動休眠し、リソース消費を削減）&lt;/li&gt;
&lt;li&gt;Alipay対面決済に対応、即時着金、自動コールバック&lt;/li&gt;
&lt;li&gt;ユーザー登録、ログイン、ログアウト、パスワード変更、アバター変更、商品レビューに対応&lt;/li&gt;
&lt;li&gt;商品管理、商品カテゴリ管理に対応&lt;/li&gt;
&lt;li&gt;注文管理、注文決済、注文発送、物流追跡に対応&lt;/li&gt;
&lt;li&gt;商品注文データ分析に対応&lt;/li&gt;
&lt;li&gt;全サイトレスポンシブデザイン&lt;/li&gt;
&lt;li&gt;フロントエンドとバックエンドの分離&lt;/li&gt;
&lt;li&gt;MySQLスレッドプール&lt;/li&gt;
&lt;li&gt;システムの基本情報設定&lt;/li&gt;
&lt;/ul&gt;
&lt;p&gt;&lt;img loading=&#34;lazy&#34; src=&#34;https://image.baidu.com/search/down?url=https://tva1.sinaimg.cn/large/78350c19ly8hu80ywg8ntj21y21f2x6p.jpg&#34;&gt;&lt;/p&gt;
&lt;p&gt;最初のバージョンでは、基本的な機能と必要な機能のみを追加しました。新機能は設計段階で既に考慮されており、データベースとコードには予約がされています（そのため、あるボタンをクリックしても反応がない場合でも心配しないでください。その背後にはまだコードがないだけです）。これらは将来のバージョンで追加される予定です。現在、ECサイトでは物理的な商品の発送形式で販売していますが、将来的には仮想商品の販売も追加し、基本的に&lt;a href=&#34;https://pay.MoeKoe.cn&#34;&gt;萌音発券&lt;/a&gt;の機能をすべて統合する予定です。&lt;/p&gt;
&lt;p&gt;&lt;img loading=&#34;lazy&#34; src=&#34;https://image.baidu.com/search/down?url=https://tva1.sinaimg.cn/large/78350c19ly8hu80ynckudj21lc1fs7wh.jpg&#34;&gt;&lt;/p&gt;
&lt;p&gt;このプロジェクトの命名は「shop」ではなく「mall」としました。そのため、将来的には単なる店舗ではなく、ショッピングモールになる可能性があります。&lt;/p&gt;
&lt;h3 id=&#34;将来&#34;&gt;将来:&lt;/h3&gt;
&lt;ul&gt;
&lt;li&gt;マルチテナントモード。ユーザーが直接ECサイトへの出店を申請し、萌音ECサイトを利用して自身の製品を販売できるようにする&lt;/li&gt;
&lt;li&gt;商品の多カテゴリ分類。製品のより詳細な仕様分類&lt;/li&gt;
&lt;li&gt;より多くの決済方法。現在、作者は他の決済権限を持っていないため、2つのみ連携済み&lt;/li&gt;
&lt;li&gt;仮想商品に対応。発券機能を統合する形となる&lt;/li&gt;
&lt;li&gt;商品ポスター宣伝画像生成&lt;/li&gt;
&lt;li&gt;メールシステム。あってもなくても良い通知機能に過ぎない&lt;/li&gt;
&lt;li&gt;右下の多機能メニュー。下部の笑顔のキャラクターがスマートナビゲーションシステムになる&lt;/li&gt;
&lt;li&gt;商品インターフェースのデータ表示を追加。データが一目でわかるように&lt;/li&gt;
&lt;li&gt;多言語対応（i18n）。国際化の流れに乗り、世界へ&lt;/li&gt;
&lt;li&gt;SMSシステム。メールシステムと全く同じ&lt;/li&gt;
&lt;li&gt;Redisキャッシュ。本来はこのバージョンで追加する予定だったが、データの制御は現状でも問題ない&lt;/li&gt;
&lt;li&gt;ダークモード。これもトレンドに追随&lt;/li&gt;
&lt;/ul&gt;
&lt;p&gt;&lt;img loading=&#34;lazy&#34; src=&#34;https://image.baidu.com/search/down?url=https://tva1.sinaimg.cn/large/78350c19ly8hu80wkxv32j21wq1f2e81.jpg&#34;&gt;&lt;/p&gt;
&lt;h3 id=&#34;ソースコードの入手方法&#34;&gt;ソースコードの入手方法？&lt;/h3&gt;
&lt;ol&gt;
&lt;li&gt;阿珏酱に233RMB以上を寄付することでソースコードを入手できます。&lt;/li&gt;
&lt;li&gt;以前に阿珏酱を支援してくださった方々（以前の支援総額が233に満たない場合は差額を補填する形で、233を超えている場合は1元を寄付して契約を再締結するだけで直接入手できます）&lt;/li&gt;
&lt;/ol&gt;
&lt;p&gt;こちらをクリックして&lt;a href=&#34;https://jq.qq.com/?_wv=1027&amp;amp;k=5cvR0GN&#34;&gt;某コミュニティ公式交流グループ&lt;/a&gt;で阿珏酱を支援してください。個人のQQリンクを貼れないため、グループリンクを貼りました。グループに参加してグループ管理者に@メンションしてください。&lt;/p&gt;
&lt;p&gt;&lt;img loading=&#34;lazy&#34; src=&#34;https://image.baidu.com/search/down?url=https://tva1.sinaimg.cn/large/78350c19ly8hu80y9po72j21ru1fi4qp.jpg&#34;&gt;&lt;/p&gt;
&lt;h4 id=&#34;なぜ商用版を設けないのか&#34;&gt;なぜ商用版を設けないのか？&lt;/h4&gt;
&lt;p&gt;なぜ商用版ではなく、寄付版なのか、その違いは何でしょうか？商用版となると、ライセンスシステムが必要になり、同時にソースコードが提供されない可能性もあり、技術サポートも必要で、さらに多くの完璧な機能が求められるでしょう。商用版のお金はプロジェクト自体に支払われるもので、作者とは利害関係、つまり商業契約のモデルであり、作者はそれ（人）に対して責任を負う必要があります。（私はこの感覚が特に好きではありません。これが私が稼げない理由かもしれませんね）&lt;/p&gt;
&lt;p&gt;一方、寄付版は、作者本人への寄付であり、個人の意思、友人同士の約束のような契約モデルであり、作者はプロジェクト自体にのみ責任を負います。&lt;/p&gt;
&lt;p&gt;もちろん、私が言葉遊びをしている、言葉の隙間を突いていると感じるかもしれません。だから、これは完全に寄付行為なのです。今回の寄付の敷居には少し商業的な雰囲気があるかもしれませんが、それは私と妻たちが生活のために稼がなければならないからです。&lt;img loading=&#34;lazy&#34; src=&#34;https://image.baidu.com/search/down?url=https://tva1.sinaimg.cn/large/78350c19ly8hu800yh27oj21t00t8kjl.jpg&#34;&gt;&lt;/p&gt;
&lt;h4 id=&#34;ヒント&#34;&gt;ヒント&lt;/h4&gt;
&lt;ul&gt;
&lt;li&gt;寄付版ではVueフロントエンドのソースコード＋コンパイル後の静的ファイル＋Node.jsバックエンドのソースファイルを提供します。&lt;/li&gt;
&lt;li&gt;すべての寄付版で入手できるのはソースファイルであり、暗号化や難読化はされていません。漏洩しないようお願いするとともに、ご自身の権利を守るためでもあります。&lt;/li&gt;
&lt;li&gt;ソースコードの変更にはある程度の基本的なプログラミング知識が必要です。もしできない場合は、変更しないでください。&lt;/li&gt;
&lt;li&gt;宝塔パネルのデプロイサービスを1回提供します。&lt;/li&gt;
&lt;li&gt;ウェブサイトのインターフェースは少女萌え系スタイルに傾倒しており、一般的な製品には適さない可能性がありますのでご注意ください。&lt;/li&gt;
&lt;li&gt;コードは複製可能であるため、契約締結後は撤回できません。何卒ご了承ください。&lt;/li&gt;
&lt;/ul&gt;
&lt;p&gt;&lt;img loading=&#34;lazy&#34; src=&#34;https://image.baidu.com/search/down?url=https://tva1.sinaimg.cn/large/78350c19ly8hu80wx88oyj21sc1g0kik.jpg&#34;&gt; 今回もこれまでと同様に、寄付版の形式でソースコードを入手できるようにしました。なぜ今回またソースコードの入手を開放したのでしょうか？以前の萌音コミュニティの影響が多少あるでしょう。萌音コミュニティは私が2ヶ月以上かけて丹念に書き上げたもので、ソースコードの寄付による入手は受け付けず、純粋に自分で運営していました。寄付を申し出た人たちは皆断りましたが、最終的には一度だけ寄付を受け取りました。結局、萌音コミュニティに申し訳ない気持ちになりました。自分の手で潰してしまい、もっと多くの人にその存在を知ってもらえなかったからです。では、なぜ直接オープンソースにしないのかというと、そうするとかえってこのプロジェクトに申し訳ないと感じるからです。誰もが簡単に手に入れられるものだと思われ、その価値が失われてしまうでしょう。直接オープンソースにはしませんが、プロジェクト関連のアーキテクチャや設計思想、一部のコードを公開し、皆さんの参考にしてもらい、学習の妨げにはならないようにします。&lt;/p&gt;</description>
    </item>
    <item>
      <title>Web3.0ベースのブロックチェーン画像アップロード</title>
      <link>https://en.moejue.cn/ja/posts/201/</link>
      <pubDate>Mon, 17 Jun 2024 12:57:43 +0000</pubDate>
      <guid>https://en.moejue.cn/ja/posts/201/</guid>
      <description>&lt;p&gt;始める前に、まず基本的な概念を簡単に理解しましょう。以下のいくつかの点にまとめました。&lt;a href=&#34;https://www.cnblogs.com/Ajue/p/18252827&#34;&gt;Web3.0とは何か、ブロックチェーンとどのような関係があるのか？&lt;/a&gt;（前回の記事がここで役立ちますね）&lt;/p&gt;
&lt;p&gt;要件：PythonベースのWeb 3.0画像アップロードシステムを開発します。このシステムは、ユーザーが画像をアップロードし、その画像を分散型ネットワークに保存し、同時にトランザクション情報をブロックチェーンに記録することを可能にします。もともとは遊びで書いていたもので、ユーザー認証やファイル操作を統合した完全な管理システムにして、「画像アップロードサービスの最終的な解決策」にしようと考えたこともありましたが、実際にやってみるとあまり現実的ではないことに気づき、断念しました。しかし、私は昔から画像にこだわりがあるのです。&lt;/p&gt;
&lt;h3 id=&#34;ステップの概要&#34;&gt;ステップの概要&lt;/h3&gt;
&lt;ol&gt;
&lt;li&gt;&lt;strong&gt;環境設定&lt;/strong&gt;：Pythonを使用して開発し、必要なPythonライブラリをインストールします。&lt;/li&gt;
&lt;li&gt;&lt;strong&gt;IPFS統合&lt;/strong&gt;：画像をIPFSにアップロードし、画像のCID（Content Identifier）を取得します。&lt;/li&gt;
&lt;li&gt;&lt;strong&gt;ブロックチェーン統合&lt;/strong&gt;：IPFSのCIDをブロックチェーンに記録します。&lt;/li&gt;
&lt;li&gt;&lt;strong&gt;Webインターフェース&lt;/strong&gt;：Flaskを使用して、ユーザーが画像をアップロードできるWebインターフェースを作成します。&lt;/li&gt;
&lt;/ol&gt;
&lt;h3 id=&#34;詳細なステップ&#34;&gt;詳細なステップ&lt;/h3&gt;
&lt;h4 id=&#34;1-環境設定&#34;&gt;1. 環境設定&lt;/h4&gt;
&lt;p&gt;必要なPythonライブラリをインストールします：&lt;/p&gt;
&lt;pre tabindex=&#34;0&#34;&gt;&lt;code&gt;pip install flask web3 ipfshttpclient
&lt;/code&gt;&lt;/pre&gt;&lt;h4 id=&#34;2-ipfs統合&#34;&gt;2. IPFS統合&lt;/h4&gt;
&lt;p&gt;IPFS（InterPlanetary File System）は、ピアツーピアのファイルストレージプロトコルです。&lt;code&gt;ipfshttpclient&lt;/code&gt;ライブラリを使用してIPFSネットワークと対話できます。&lt;/p&gt;
&lt;p&gt;まず、IPFSノードをインストールして実行していることを確認してください。まだIPFSをインストールしていない場合は、&lt;a href=&#34;https://ipfs.io&#34;&gt;IPFS公式サイト&lt;/a&gt;でインストールガイドを見つけることができます。&lt;/p&gt;
&lt;p&gt;以下は、画像をIPFSにアップロードするコード例です：&lt;/p&gt;
&lt;pre tabindex=&#34;0&#34;&gt;&lt;code&gt;import ipfshttpclient

def upload_to_ipfs(file_path):
    client = ipfshttpclient.connect(&amp;#39;/ip4/127.0.0.1/tcp/5001&amp;#39;)
    res = client.add(file_path)
    return res[&amp;#39;Hash&amp;#39;]
&lt;/code&gt;&lt;/pre&gt;&lt;h4 id=&#34;3-ブロックチェーン統合&#34;&gt;3. ブロックチェーン統合&lt;/h4&gt;
&lt;p&gt;&lt;code&gt;web3.py&lt;/code&gt;ライブラリを使用してIPFSのCIDをブロックチェーンに記録します。ここではイーサリアム（Ethereum）をサンプルブロックチェーンとして使用します。&lt;/p&gt;
&lt;p&gt;以下は、IPFSのCIDを保存するための簡単なスマートコントラクトの例です：&lt;/p&gt;
&lt;pre tabindex=&#34;0&#34;&gt;&lt;code&gt;pragma solidity ^0.8.0;

contract IPFSStorage {
    mapping(address =&amp;gt; string[]) public userCIDs;

    function storeCID(string memory cid) public {
        userCIDs[msg.sender].push(cid);
    }

    function getCIDs() public view returns (string[] memory) {
        return userCIDs[msg.sender];
    }
}
&lt;/code&gt;&lt;/pre&gt;&lt;p&gt;このコントラクトをコンパイルしてデプロイした後、以下のPythonコードを使用してスマートコントラクトと対話します：&lt;/p&gt;</description>
    </item>
    <item>
      <title>ESP8266-NodeMCU開発ボードを使って、私のQQアバターを表示してみる。</title>
      <link>https://en.moejue.cn/ja/posts/200/</link>
      <pubDate>Sun, 16 Jun 2024 12:50:42 +0000</pubDate>
      <guid>https://en.moejue.cn/ja/posts/200/</guid>
      <description>&lt;p&gt;ええ、自分でESP8266開発ボードのファームウェアを書くと言っていた私が戻ってきました。20年前に約束した通り、今日、その願いを叶えに戻ってきました。&lt;a href=&#34;https://www.cnblogs.com/Ajue/p/18202561&#34;&gt;ESP8266串口WiFi模块 - WiFi杀手&lt;/a&gt;&lt;/p&gt;
&lt;p&gt;今日はOLEDディスプレイも接続します。今回購入したのは4ピンのOLED（128*64）で、カラー表示には対応していません。&lt;/p&gt;
&lt;h3 id=&#34;nodemcu開発ボード&#34;&gt;NodeMCU開発ボード&lt;/h3&gt;
&lt;p&gt;NodeMCUはオープンソースのIoTハードウェア開発ボードです。WIFI機能をサポートし、Arduino開発ボードと非常に似た使用方法であるため、近年、世界中のメイカーたちからますます人気を集めています。NodeMCUのサイズはArduino Nanoに似ています。Arduinoチームによって開発されたものではありませんが、Arduino IDEを使用して開発することも可能です。&lt;/p&gt;
&lt;p&gt;あらゆるものがインターネットに接続されるIoTの基盤として、まずIoT制御ボードのコストが高すぎてはいけません。高価なIoT制御コンポーネントは、プロジェクトのコスト管理に不利であり、多くのメイカー愛好家が学習し使用する上でも不利です。この点において、NodeMCUはRaspberry PiやArduinoファミリーのIoTプラットフォームなどよりも優位性があります。&lt;/p&gt;
&lt;p&gt;注意深い方はすでにお気づきかもしれませんが、私の開発ボードはESP8266-NodeMCUと呼ばれています。しかし、他のウェブサイトや資料では、ESP8266と表記されたり、NodeMCUと表記されたりすることがあります。では、ESP8266とNodeMCUの間にはどのような関係があるのでしょうか？&lt;/p&gt;
&lt;p&gt;ESP8266はチップ（鉄製のケースに収められた四角いもの）であり、NodeMCUはESP8266チップを核とした開発ボードです。下の図に示す通りです。 &lt;img loading=&#34;lazy&#34; src=&#34;https://image.baidu.com/search/down?url=https://tva1.sinaimg.cn/large/78350c19ly8hu4vo3lpljj21hc140n7w.jpg&#34;&gt; 小さなチップのピンをコンピューターに接続し、プログラムをアップロードするなどの操作を行うのは非常に困難であるため、ESP8266チップを中心とした様々な開発ボードが誕生しました。NodeMCUもこれらの開発ボードの一つです。&lt;/p&gt;
&lt;p&gt;NodeMCU開発ボード上の2列のピンヘッダーは、ESP8266チップのピンに接続されています。開発ボード上の2列のピンヘッダーがあれば、デュポン線を使ってチップのピンを実験回路に簡単に接続できます。NodeMCU開発ボードにはUSBポートと電圧変換回路も搭載されています。これらは私たちに大きな利便性を提供します。USBデータケーブル1本で、ESP8266への給電とプログラムのアップロードを簡単に実現できます。もちろん、NodeMCU開発ボードの回路機能はこれだけではありませんが、これ以上は深掘りしません。&lt;/p&gt;
&lt;h3 id=&#34;ドライバーのインストール&#34;&gt;ドライバーのインストール&lt;/h3&gt;
&lt;p&gt;以前にも開発ボードのドライバーインストールについては説明しましたが、十分詳細ではありませんでした。&lt;/p&gt;
&lt;p&gt;現在市販されているESP8266ドライバーには様々な種類があり、同じNodeMCU開発ボードであってもドライバーが異なる場合があります。現在主流なのはCH340とCP210Xのドライバーです。&lt;/p&gt;
&lt;p&gt;ドライバーのダウンロードは、チップメーカーの公式サイトから直接行ってください。 CP210X：&lt;a href=&#34;https://cn.silabs.com/developers/usb-to-uart-bridge-vcp-drivers&#34;&gt;https://cn.silabs.com/developers/usb-to-uart-bridge-vcp-drivers&lt;/a&gt; CH340C：&lt;a href=&#34;https://www.wch.cn/downloads/CH341SER_EXE.html&#34;&gt;https://www.wch.cn/downloads/CH341SER_EXE.html&lt;/a&gt;&lt;/p&gt;
&lt;p&gt;ご自身のプラットフォームに適したドライバーインストーラーをダウンロードしてください。ご自身のシリアルチップのモデルがドライバーのサポート範囲内にあるか、よく確認する必要があります。&lt;/p&gt;
&lt;h3 id=&#34;自分の開発ボードに必要なドライバーを確認する方法&#34;&gt;自分の開発ボードに必要なドライバーを確認する方法&lt;/h3&gt;
&lt;ol&gt;
&lt;li&gt;直接見る。下の図の縦長の黒い長方形がUSB-シリアル変換チップです。その上にチップのモデル名が記載されています。 &lt;img loading=&#34;lazy&#34; src=&#34;https://image.baidu.com/search/down?url=https://tva1.sinaimg.cn/large/78350c19ly8hu4voc3xefj21hc140n7w.jpg&#34;&gt;&lt;/li&gt;
&lt;li&gt;購入した販売店に尋ねる。&lt;/li&gt;
&lt;/ol&gt;
&lt;h3 id=&#34;ディスプレイのはんだ付け&#34;&gt;ディスプレイのはんだ付け&lt;/h3&gt;
&lt;p&gt;はんだ付けを間違えないでください。間違えるとチップが焼損します。OLEDの配線：&lt;/p&gt;
&lt;ul&gt;
&lt;li&gt;GND - GND&lt;/li&gt;
&lt;li&gt;VCC - VCC&lt;/li&gt;
&lt;li&gt;SCL - GPIO5(D1)&lt;/li&gt;
&lt;li&gt;SDA - GPIO4(D2)&lt;/li&gt;
&lt;/ul&gt;
&lt;p&gt;はんだごて加熱中 &lt;img loading=&#34;lazy&#34; src=&#34;https://image.baidu.com/search/down?url=https://tva1.sinaimg.cn/large/78350c19ly8hu4voij5a5j21hc1404dj.jpg&#34;&gt;&lt;/p&gt;
&lt;p&gt;以下がはんだ付け完了したものです。配線に注意してください。この順番であるとは限りません。名称を確認してください。 &lt;img loading=&#34;lazy&#34; src=&#34;https://image.baidu.com/search/down?url=https://tva1.sinaimg.cn/large/78350c19ly8hu4voof65aj21hc140dqi.jpg&#34;&gt;&lt;/p&gt;
&lt;h3 id=&#34;arduino-ideのインストール&#34;&gt;Arduino IDEのインストール&lt;/h3&gt;
&lt;ol&gt;
&lt;li&gt;
&lt;p&gt;Arduino IDEをダウンロード &lt;a href=&#34;https://www.arduino.cc/en/software&#34;&gt;https://www.arduino.cc/en/software&lt;/a&gt;&lt;/p&gt;
&lt;/li&gt;
&lt;li&gt;
&lt;p&gt;インストール。インストールまで私が教える必要がありますか？&lt;/p&gt;
&lt;/li&gt;
&lt;li&gt;
&lt;p&gt;設定。「ツール」-「ボード」-「ボードマネージャー」をクリックし、設定でボードアドレスを記述します：&lt;a href=&#34;http://arduino.esp8266.com/stable/package_esp8266com_index.json&#34;&gt;http://arduino.esp8266.com/stable/package_esp8266com_index.json&lt;/a&gt; その後、対応するサポートライブラリファイルが自動的にダウンロードされます。この間、ネットワークの安定性を確保する必要があります。&lt;/p&gt;
&lt;/li&gt;
&lt;li&gt;
&lt;p&gt;開発ボードを選択: NodeMCU1.0(ESP-12EModule)&lt;/p&gt;
&lt;/li&gt;
&lt;li&gt;
&lt;p&gt;ポートを選択: コンピューターのデバイスマネージャーで開発ボードのCOMポートを見つけます。&lt;/p&gt;
&lt;/li&gt;
&lt;/ol&gt;
&lt;h3 id=&#34;arduinoコード&#34;&gt;Arduinoコード&lt;/h3&gt;
&lt;p&gt;時々、私が長々と説明するよりも、直接コードを見せる方が手っ取り早いと感じます。あなたもきっと、私の無駄話を聞くよりも直接コードを見たいと思っているでしょう。私も可能な限りコードにコメントを付けました（Arduinoコードの記述はC/C++言語の規範に従ってください）。&lt;/p&gt;
&lt;p&gt;以下の例では、WiFi接続にはライブラリを使用しています。初回接続時には、ESP8266が発信するWiFiに携帯電話で接続し、ネットワーク設定を行う必要があります。画面への書き出しにはライブラリを使用しており、中国語の直接書き出しをサポートしています。&lt;/p&gt;
&lt;ol&gt;
&lt;li&gt;これは、WiFi接続と画面への画像表示の簡単な例です。&lt;/li&gt;
&lt;/ol&gt;
&lt;pre tabindex=&#34;0&#34;&gt;&lt;code&gt;#include &amp;lt;Adafruit_GFX.h&amp;gt;
#include &amp;lt;Adafruit_SSD1306.h&amp;gt;
#include &amp;lt;ESP8266WiFi.h&amp;gt;
#include &amp;lt;NTPClient.h&amp;gt;
#include &amp;lt;WiFiManager.h&amp;gt;
#include &amp;lt;U8g2lib.h&amp;gt;

#define SDA 4  // SDA引脚，默认gpio4(D2)
#define SCL 5  // SCL引脚，默认gpio5(D1)

Adafruit_SSD1306 oled(128, 64, &amp;amp;Wire,-1);   //OLED 屏幕实例化
WiFiUDP ntpUDP;

NTPClient timeClient(ntpUDP,&amp;#34;pool.ntp.org&amp;#34;, 8*3600, 60000);

U8G2_SSD1306_128X64_NONAME_F_SW_I2C u8g2(U8G2_R0, /*clock=*/SCL, /*data=*/SDA, /*reset=*/U8X8_PIN_NONE);           // 选择显示屏幕

// 只执行一次
void setup() {

  u8g2.begin();            // 初始化
  u8g2.enableUTF8Print();  // UTF8允许
  u8g2.setFont(u8g2_font_wqy12_t_gb2312b); //字体大小   u8g2_font_wqy15_t_gb2312b  

  // 初始化屏幕
  OLED_Init();

  OLED_Showchin(1,13,&amp;#34;正在连接WiFi....&amp;#34;,0);
  WiFiManager wifiManager;
  wifiManager.autoConnect(&amp;#34;ESP8266&amp;#34;);

  OLED_Showchin(1,27,&amp;#34;WiFi连接成功！&amp;#34;,0);
  OLED_Showchin(1,41,&amp;#34;名称： &amp;#34; + WiFi.SSID(),0);
  OLED_Showchin(1,55,&amp;#34;IP: &amp;#34; + WiFi.localIP().toString(),1);

  // 获取时间
  timeClient.begin();
  u8g2.setFont(u8g2_font_wqy15_t_gb2312b); //字体大小   u8g2_font_wqy15_t_gb2312b  

  OLED_Showchin(1,13,&amp;#34;宁小建&amp;#34;,0);
  OLED_Showchin(1,27,&amp;#34;hhhhhhhhhhhh&amp;#34;,0);
  OLED_Showchin(1,55,&amp;#34;大傻逼哈哈哈&amp;#34;,1);

  timeClient.update();
  OLED_Showchin(1,20,&amp;#34;当前北京时间: &amp;#34;,0);
  OLED_Showchin(1,41,timeClient.getFormattedTime(),1);
  delay(1000);
  OLED_img();
}

// 重复执行程序
void loop() {
  // 更新时间
  // timeClient.update();
  // OLED_Showchin(1,27,&amp;#34;当前北京时间: &amp;#34;,0);
  // OLED_Showchin(1,41,timeClient.getFormattedTime(),0);
}

// 打印输出到屏幕（支持中文）
void OLED_Showchin(uint8_t x, uint8_t y, String string, uint8_t boot) {
  u8g2.setCursor(x, y);  //设置显示坐标
  u8g2.print(string);  // 指定缓存区需要打印的字符串
  u8g2.sendBuffer();          // 将定位信息发送到缓冲区
  if(boot == 1){
    delay(1000);
    u8g2.clearBuffer();     // 清除缓存，其实初始化里有清除，循环时一定要加上
  }
}

// 屏幕初始化
void OLED_Init() {
  oled.begin(SSD1306_SWITCHCAPVCC, 0x3C);     //&amp;#34;SSD1306_SWITCHCAPVCC&amp;#34;表示显示器为OLED ,&amp;#34;0x3C&amp;#34;为OLED屏幕默认通信地址
  oled.setTextColor(WHITE);//开像素点发光
  oled.clearDisplay();//清屏
}

// 输出屏幕
void OLED_ShowString(uint8_t x, uint8_t y, uint8_t font_size, String string) {
  oled.setTextSize(font_size);    //设置字体尺寸 (&amp;gt;=1)
  oled.setCursor(x, y);           //设置显示坐标
  oled.println(string);           //显示内容
  oled.display();                 //开启显示
}

// 绘画
void OLED_img() {
  //  图片数据
    const unsigned char gImage_1[518] = { 0X00,0X01,0X40,0X00,0X40,0X00,
  0X00,0X40,0X00,0X00,0X00,0X3E,0XF0,0X00,0X00,0X80,0X00,0X00,0X00,0X1F,0XE0,0X00,
  0X00,0X00,0X00,0X00,0X00,0X06,0XB0,0X00,0X01,0X00,0X00,0X00,0X00,0X03,0XF8,0X00,
  0X00,0X00,0X00,0X00,0X00,0X03,0XFC,0X00,0X00,0X00,0X00,0X00,0X00,0X03,0XDC,0X00,
  0X04,0X00,0X00,0X00,0X00,0X01,0XC0,0X00,0X0E,0X00,0X00,0X00,0X00,0X00,0X80,0X00,
  0X06,0X00,0X00,0X00,0X00,0X00,0X00,0X00,0X01,0X00,0X00,0X00,0X10,0X00,0X00,0X00,
  0X08,0X00,0X00,0X00,0X0E,0X00,0X00,0X00,0X08,0X00,0X00,0X00,0X8F,0X00,0X00,0X00,
  0X00,0X00,0X02,0X02,0X47,0X00,0X00,0X00,0X00,0X00,0X01,0X10,0X63,0X80,0X00,0X00,
  0X00,0X00,0X01,0XC9,0X73,0XC0,0X00,0X00,0X00,0X00,0X00,0XE4,0X79,0XE0,0X00,0X00,
  0X00,0X02,0X00,0XFA,0XF9,0XE0,0X00,0X00,0X10,0X02,0X00,0X7D,0X8C,0XF0,0X00,0X00,
  0X10,0X03,0X01,0X7E,0X90,0XF1,0X80,0X00,0X10,0X01,0X20,0XFD,0X1C,0X7B,0XE0,0X00,
  0X00,0X01,0XA0,0X7D,0X03,0X7B,0X20,0X00,0X10,0X01,0XD8,0XFF,0X8B,0X7E,0X30,0X00,
  0X00,0X01,0XFC,0X7F,0X83,0XB6,0X10,0X00,0X00,0X00,0XF7,0XFF,0XC7,0XBE,0X10,0X00,
  0X00,0X01,0X8F,0XFF,0XE3,0XF6,0X10,0X00,0X01,0X01,0X4F,0XFF,0XFF,0XFF,0X10,0X00,
  0X00,0X01,0XCF,0XFF,0XFF,0XDF,0X10,0X00,0X00,0X01,0XC3,0XFF,0XFF,0XDF,0X70,0X00,
  0X01,0X03,0XE3,0XFF,0XFF,0XDF,0XE0,0X00,0X04,0X01,0XE7,0XFF,0XFF,0XDF,0XE4,0X00,
  0X07,0X00,0XFB,0XFF,0XFF,0XDF,0XC0,0X00,0X07,0X00,0XFB,0XFF,0XFF,0XFE,0X00,0X00,
  0X13,0X00,0X7F,0XFF,0XFF,0XFC,0X00,0X00,0X01,0X20,0X3F,0XFF,0XFF,0XFC,0X00,0X00,
  0X00,0X00,0X3F,0XFF,0XFF,0XF8,0X00,0X0B,0X00,0X00,0X1F,0XFE,0X0F,0XF8,0X00,0X1F,
  0X00,0X00,0X1F,0XF8,0X6F,0XF0,0X00,0XFF,0X00,0X00,0X1F,0XE1,0XFF,0XF0,0X05,0XFF,
  0X00,0X00,0X0F,0XF3,0XFF,0XE0,0X03,0XFF,0X00,0X40,0X0F,0XF7,0XFF,0XC0,0X07,0XFF,
  0X00,0X00,0X07,0XFF,0XFF,0X80,0X07,0XFF,0X08,0X00,0X07,0XFF,0XFF,0X00,0X0F,0XFF,
  0X00,0X00,0X23,0XFF,0XFE,0X00,0X0F,0XFF,0X00,0X08,0X60,0XFF,0XFE,0X00,0X0F,0XFF,
  0X00,0X40,0X20,0X3F,0XFE,0X00,0X1F,0XFF,0X00,0X00,0X10,0X0B,0XFF,0X80,0X1F,0XFF,
  0X00,0X00,0X40,0X00,0X3F,0X00,0X1F,0XFF,0X00,0X00,0X10,0X00,0X3F,0X00,0X1F,0XFF,
  0X20,0X00,0X02,0X00,0X3F,0X00,0X3F,0XFF,0X00,0X00,0X00,0X00,0X7F,0X80,0X3F,0XFF,
  0X00,0X00,0X00,0X10,0X7F,0X80,0X7F,0XFF,0X00,0X00,0X00,0X80,0X7F,0X80,0X7F,0XFF,
  0X10,0X00,0X00,0X00,0X7F,0X80,0XFF,0XFF,0X30,0X00,0X00,0X00,0X7F,0X80,0XFF,0XFF,
  0X10,0X10,0X00,0X00,0X7F,0XC1,0XFF,0XFF,0X00,0X00,0X00,0X00,0X7F,0XF3,0XFF,0XFF,
  0X00,0X00,0X01,0X00,0X3F,0XFF,0XFF,0XFF,0X00,0X00,0X00,0X04,0X3F,0XFF,0XFF,0XFF,
  0X00,0X00,0X00,0X00,0X3F,0XFF,0XFF,0XFF,0X00,0X00,0X10,0X80,0X1F,0XFF,0XFF,0XFF,
  0X01,0X00,0X00,0X05,0X1F,0XFF,0XFF,0XFB,0X00,0X00,0X00,0X00,0X1F,0XF7,0XFF,0XFC,
  0X00,0X00,0X00,0X00,0X1F,0XFB,0XFF,0XFF,0X00,0X00,0X40,0X00,0X19,0XFF,0XFF,0XFF,
  };

  oled.clearDisplay();
  oled.drawBitmap(3, 1, gImage_1, 64, 64, WHITE);
  oled.display();
}
&lt;/code&gt;&lt;/pre&gt;&lt;p&gt;&lt;img loading=&#34;lazy&#34; src=&#34;https://image.baidu.com/search/down?url=https://tva1.sinaimg.cn/large/78350c19ly8hu4vppewusj21hc140qb3.jpg&#34;&gt;&lt;/p&gt;</description>
    </item>
  </channel>
</rss>
