GCPのcloud_sql_proxyでReady for new connectionsから点灯していて進まないと思っている方向け

こんにちは。

ASUKARUでは、最近GCP(Google Cloud Platform)を推してします。理由は様々ですが、固定額のレンタルサーバーもいいですが(安心感あり)、できることがやはり限られていることと、SEO対策のために様々なことをしなければならないためです。

佐賀県の神埼市では、サーバーはだいたいレンタルサーバーであることが多いですが、サイトの構築に力をいれていくための時間もないって方には本当におすすめです。

 

さて、GCPでのデータベースへの接続なのですが、今回は「え??データベースに接続しようしてcloud_sql_proxyをダウンロードしてきたけど接続できてんの?」っていう方向けの記事になっています。

今回は

  • Windows10 Pro
  • PyCharm(エディタ) Pro
  • DBはまさかのXAMPP(笑)

 

Python(Django)での開発だったのですが、まぁ・・・・。

 

さて、WEBアプリケーションなので、実際にはDBとの通信が必要ですね。通常(ローカル環境)であれば単純な話なのですがGCPで行おうとするとちょっと話が変わってきます。

でも全部を記述することは難しいので、いったん以下を前提にします。

 

  • GCPのアカウントは設定されている
  • cloud_sql_proxyはダウンロード済み
  • gcloudコマンドで認証は通してある(gcloud auth login)
  • sqlの作成やAPIも有効化されてある

 

それでは、cloud_sql_proxyを使って(今回はPyCharmのTerminalを使用していますがコマンドプロンプトからでも同じです)GCPのsqlに接続していきます。

 

まずは、cloud_sql_proxyを自分の作業環境ディレクトリにまで移動させてください。

cloud_sql_proxy
cloud_sql_proxy

だいたい、GCPにデプロイするファイルと同列になるかと思います。

次に、PyCharmのターミナルから、

sqlコマンド
cloud_sql_proxy_commandはこれを使ってください。

 

-instancesのところは、ご自身のGCPのSQL接続インスタンス名に書き換えてください。

お決まりですね。

cloud_sql_proxy -instances=<接続インスタンス名>=tcp:3306

 

 

すると、以下のようになって接続が完了したのかどうかわからないかと思います。

CloudSQLへ接続を試みようとしている状態
CloudSQLへ接続を試みようとしている状態

 

そして、待てど暮らせどこのまま先に進みません。

他のコマンド(たとえばInstallするようなコマンド)であればここで「success!!」なり「warning」なり反応をしてくれるのですが、このまま進行していかない状態に頭を悩まされる方もいらっしゃるかもしれません。

でも、実はこの最後のメッセージをみていただきたいのですが、

「Ready for  new connections」

と書いてあります。

そうか。そうか。このまま待っていれば接続してくれるのか。と思っている方は、残念ですが待っていてもダメです。

 

なんと!!ここでこの状態はそのままにしておいて、別にローカルのMySQLに接続していく必要があるのです!

 

 

え??って思われた方は、ドキュメントをよく読まれてください。

ドキュメントを読む暇なんてない!って方は、このまま進んでいってください(笑。

2020/04/18 07:35:45 Listening on 127.0.0.1:3306 for <ご自身のインスタンス名>
2020/04/18 07:35:45 Ready for new connections

これは、つまりローカルのDBとSQLインスタンスを接続するよ!こっち(SQLインスタンス)の準備はできてるよ!待ってるよ!っていう意味の「Ready for new connections」なんです。

SQLインスタンスの準備をしているよ!」っていう意味のメッセージではありません(爆

 

で、話を元に戻して「じゃあ、ここから何をすればいいのか!」ってことなのですが、

ローカルのMySQLに接続してください。その際ですが、「Listening on 127.0.0.1:3306 for <ご自身のインスタンス名>」がジャブのように効いてきます。これは「SQLインスタンスは127.0.0.1:3306 」で待ってるよ!接続してね!」っていうことなので、ここに向かって接続をしてあげる必要があります。

そのため、ローカルのMySQLに接続するときにはいつものように「mysql -u root -p」とするだけではなく、以下のようなコマンドを叩く必要があります。

少ないとは思いますが、XAMPPのローカルDBを使っている場合は、

XAMPPのSHELLを叩いてターミナルにアクセス
XAMPPのSHELLを叩いてターミナルにアクセス

 

XAMPPのコンパネの「SHELL」をクリックしてターミナル側へアクセスしてください。

きちんとDockerなどで環境を構築している方はその環境のMySQLに接続するようにしてください。

ターミナルには、以下のコマンドを入力します。

 mysql -u <SQLインスタンスに設定したユーザー名> -p --host 127.0.0.1

この–hostオプションが先ほどの待っている場所(Listening on 127.0.0.1:3306)になるわけです。

 

このコマンドを実行すると、パスワードの入力を求められるかと思います。SQLインスタンスで設定したパスワードを入力してください。

shellからクラウドSQLへ接続完了
shellからクラウドSQLへ接続完了

 

こんな感じになりますでしょうか。

「Welcome to the MariaDB monitor.」と出ていれば大丈夫です。

 

そして、先ほどのPyCharmのターミナルの方へ戻ってみましょう。

「New Connection」という表示が出ていれば問題なく接続ができています。あとは、ローカルとサーバー環境の処理切り分けなどを設定ファイルに記述してください。そうすればうまく開発していけると思います。

 

長くなりましたが。

 

今日もいい一日でありますように!

 

 

 

Djangoで開発用サーバーにChromeなどでアクセスできないときの対処方法

こんにちは。

佐賀県はコロナの影響もそれほど大きくはないですが、全国的には大問題になっているところですね。

さて、そんな中ですが、DjangoというPythonでWEBアプリを開発するフレームワークがあるのですが、こちらで開発をしているときに、開発用サーバーにChromeなどでアクセスすることができないということがありましたので解決方法をあげておきたいと思います。

 

たとえば、こんな感じになります。

Djangoの開発用サーバーを立ち上げるコマンドである、

python manage.py runserver

を叩いたときの症状です。

Djangoで開発用サーバーを立ち上げてもブラウザからアクセスできない
Djangoで開発用サーバーを立ち上げてもブラウザからアクセスできない

 

このまま開発用サーバーである、127.0.0.1:8000にChromeなどでアクセスをしても下記の画像の通りにしか表示されないのではないでしょうか。

 

Djangoの開発用サーバーでアクセスしたときのブラウザの表示
Djangoの開発用サーバーでアクセスしたときのブラウザの表示

 

 

これは、Chromeなどではhttpsアクセスが標準化しているためにアクセスができないということになってしまっています。

今のところ、私の手元にあるブラウザではほとんどがアクセスすることができません。

 

というわけで、これをhttps化してしまえばOKということです。

サーバーにデプロイするときには、もちろんSSL証明などを取得してSSL化には対応するかと思います。ここでは、ローカル環境(DockerやVagrantなどを使用しないケース)での話を前提にしております。単純に、これだけのためにDockerの環境を導入するのは・・・と思っていらっしゃる方へ向けての解決策になります。

 

 

【 解決策 】

これを解決するための方法としては単純なんですが、django-sslserverというのをインストールしてあげれば大丈夫です!

 

pip install django-sslserver

 

 

簡単ですね。

 

そして、このライブラリを使うことをDjango側へ教えてあげる必要があります。

 

settings.pyを開いて、INSTALLED_APPSのところに追加してください。

INSTALLED_APPS = [
    'accounts.apps.AccountsConfig',
    'django.contrib.admin',
    'django.contrib.auth',
    'django.contrib.contenttypes',
    'django.contrib.sessions',
    'django.contrib.messages',
    'django.contrib.staticfiles',
    'sslserver', # 追加
]

Djangoではお約束ですね。

 

でもこれだけでは開発用サーバーがSSL化されません。

SSLで開発用サーバーを立ち上げるためには、以下のコマンドでサーバーを立ち上げてください。

 

python manage.py runsslserver

 

これでSSL化されたサーバーを立ち上げることができたかと思います。

Django SSL化を対応
Django SSL化を対応

 

 

ただし、これはあくまで開発用サーバーを立ち上げるときの話なので、本番環境ではきちんとSSL証明書を取得してそれをNginxなりApacheなどに読み込ませてくださいね

 

 

Wagtail PythonでCMSを実装してみる

今回、CMSの調査をしていまして、出てきたWagtailを使ってみました。その際の簡単な説明だけ残しておこうと思います。

まずプロジェクトであがってきたのはDjangoを使用してCMSを搭載させれるかどうかということでした。そのためのパッケージもあるようです。ですが、調べていたらどうやらWagtailの方がいいのかどうかということでいったん使い勝手的なところ調査しました。

以下、説明していきます。

 

1.インストール

まずはインストールからですが、これは問題ないのではないかと思います。ただ、私が勘違いしていたのははじめにDjangoのプロジェクトを設定してからWagtailをいれると思っていましたが、公式ドキュメントをみて「あれ??」ということで単純にPythonの仮想環境を作成してそこにWagtailを落としてきました。

********************

2.プロジェクト作成

次に、プロジェクト作成です。ここでもちょっとはまりました。

こちらのサイトをみていたのですが、

wagtail start mysite mysite

 

これでは作成できませんでした。

以下のようなエラーが返ってきました。

Creating a Wagtail project called cms
CommandError: Destination directory 'C:\cms\cms' does not exist, please create it first.

 

そこで、DjangoでもLaravel でもなんでもそうかと思いますが、使えるコマンドを確認することができるので、試してみることに。

(myvenv) C:\cms>wagtail
Type 'wagtail help <subcommand>' for help on a specific subcommand.

Available subcommands:

    start               Creates the directory structure for a new Wagtail project.
    updatemodulepaths   Update a Wagtail project tree to use Wagtail 2.x module paths

 

きちんと出てきてくれましたね。

プロジェクトを作成するためには、どうやら

wagtail start <プロジェクト名>

 

を叩く必要があるようです。

 

Wagtail_start_command
Wagtail_start_command

すると、写真のようなファイル群が作成されます。

では、ここから様々なことをやっていきたいと思います。

 

って、あれ?フォルダの中身とかほとんどDjangoみたいなものではないですか。

しかもDockerファイルまで生成してくれています。ありがたい。

 

 

いったん中身をいじるのに専念したいので

続きはまた次回。

 

画像データから一気に数値を取得してくる。資料作成の時短へ

こんにちは!
久しぶりの投稿をしています。ASUKARUの遠藤です。

よく、お見積りを作成する場合などで、すでにあるものを転写することってあるかもしれませんが、今日はそんなときに役立つかもしれないツールを開発しましたので掲載しておきます。

たとえば、下記のような情報群があったときに、

 

これぐらいならいいですが、実際には相当の量を入力する必要があったりしますのでそれをそのまま転記していると膨大な時間がかかってしまいます。

そこで、こういったものを画像化してしまって(画面キャプチャなどでOK!)、そこから数値だけを取得してくれば転記作業もかなり楽になります。

 

そこで、実際にやってみた結果が

このようになりました。

日付部分と「o7」など、少し違うところがあるので、ここは修正をしていければあとは大凡OKではないでしょうか。

 

さて、このような方法の活用場所は随所にあります。

たとえば、

  • 先方様からいただいた見積りなどを自社でペーパーレス管理する(画像を読み込んで、必要な形で管理すれば可能)

  • PDFファイルから文字認識・画像認識を使って、簡単に管理できるようにする

  • 何かの転記作業を効率化する

 

など、活用されるところは多いかと思います。

 

処理結果のところは、現時点ではコンソールに出力をしておりますが、実際にはCSV、EXCELなどに直接吐き出しても問題ないかと思います(現時点ではCSVへの出力を行っています)。

 

また、日本語などへの対応や、文字化けが気になるという方にはそれぞれやり方がありますので個別にご相談ください。

 

では、また次回!

 

 

ASUKARU WEBシステム

1. 乗船料金自動算出システム

蒲江交通乗船料金算出システム

蒲江交通有限会社様の料金試算システム(料金表は2014年)になります。ここではこれまで不透明さがあった乗船料金を簡単に計算することができるようなシステムとしました。

demoはこちら

 

 

2. 指定のサイトから特定のキーワードを取得するシステム

特定のキーワードを取得するシステムーASUKARU

特定のサイトURLからキーワードを抽出してくるシステムを作りました。

demoはこちら

 

3. Google Map API で エリアマーケティングのマップを表示

GoogleMapAPI

こちらは、エリアマーケティングのためにGoogleMapAPIを活用してシステムを構築したものの一部になります。

完全版はお見せすることはできませんが、参考までに

ログインID: sample@sample.com

パスワード: sample

demoはこちら

 

4.  船舶内にて海産物をクレジットカード決済で購入できる

PaypalAPI

蒲江交通有限会社にて乗船中に、蒲江の美味しい海の幸を購入できるようにしました。しかもクレジットカード決済を搭載していましたので、現金の受け渡しはその場では必要でなく、商品の引き渡しだけでしたので大くのお客様をたった一人でさばくことができました。

demoはこちら

 

5. cocoroさんのシステムを開発

Cocoroさんのシステム

ケーキ屋さんのCocoroさん。

そこでのシステムを開発中です。

 

 

 

6. 特定の場所にアップロードした画像を表示

ケーキのデコレーション用に、ということでしたが、ここではベジータに代用してもらい、画像をアップロードしてベジータの画面に表示させるというシステムになります。

demoはこちら

 

 

 

 

 

 

7. スマホ修理対応システム(顧客管理・業務管理)

スマホ修理対応システム

こちらは、スマホ修理を事業として展開している方のための顧客管理・業務管理システムです。

特に予約の受付から、来店頻度やサポート体制、修理に要する時間などをDBに保存し、集計、データ化することができます。

demoはこちら

 

8. QRコード発行システム

こちらはQRコードを発行するシステムになります。長い文字はQRコードの画像画面を真っ黒にしてしまうため、一旦URLを短縮してQRコードを生成、発行することでQRコード自体が真っ黒になることを防ぎます。

demoはこちら

 

 

9. ブログ投稿システム

ブログを投稿するシステム。

 

demoはこちら

 

 

 

10. サプリメントのLP制作

サプリメントのランディングページです。このページでは、顧客属性データを収集して、今後の分析に活かせるようにDBにデータを保存することができるようにしています。

管理画面では、こういった顧客属性のデータをリアルタイムで把握して展開ができるようにしています。

 

demoはこちら

 

 

 

 

 

以上は、直近1年以内のものになります。

ASUKARU-*- アスカル -*- WEBサイト運営サポート(運営代行)の記録

こんにちは。
昨日の激しい雨のあとは、蝉の声と涼しい風。今朝も6時ごろから近くのクリークへとバスを求めて遊びに行きましたが、どうやら昨日の豪雨のせいもあってか濁りが激しく、釣行時間20分程度で切り上げて帰宅しました。
こうやって遊んでいても、WEBサイトとは運営をされているもので、ビジネスにとって有益な情報を与えてくれます。

ホームページ・WEBサイトの運営をサポート

ただ、ホームページの運営というのは、結構自分で情報を取得してきて比較したりしないといけなかったりするので、手間のかかる作業ではあります。
我々の方では、このような面倒な作業を自動化するツールを作りました。
興味のある方はこちらからお問い合わせください。
また、このブログの下の方に連絡先なども記載をしておりますので、そちらの方へ直接ご連絡をいただいても構いません。
もう少し具体的にどのようなものなのか、と言いますと、

1.上位表示されるサイトとの差分を取得

これまでGoogleのアナリティクスを見てみても、自分のサイトの情報しかとれてこなったと思います。競合相手のサイトなどは、他の検索ツールを使用したりしない限りは取得できないので、そういったツールの存在を知って、有料版であればお金を払わないと自分のサイトへの流入が高いとか、低いとか、あるいは良いとか悪いとかっていう評価自体が難しいところでした。このASUKARU(アスカル)のシステムは、そんな流れ一切を自動的に取得をしてきます。

2.訪問したユーザーの属性に応じて、WEBサイトのデザインを自動的に変更

よくWEBサイトのデザインの話の中で、「ターゲットは女性ですか、男性ですか」というような話を耳にしたことがあるかと思います。要は、男性向けのデザインと女性向けの柔らかいデザインとの間には差があるということです。このWEBサイトのサポートは、自動的にこのようなデザインの差を訪問者の属性に応じて変化させることができます。そうすると、もはやWEBサイト一つでマスマーケティングの世界に入ってくるということになります。

3.もっともコンバージョンの高いサイトを機械学習することでWEBサイトの最適化を図る。

WEBサイトやホームページというのは、本当は目的を持って存在をしています。「なんとなく今の時代ホームページぐらい持ってないと・・・」という気持ちで作られたサイトも、それだけで意味を与えられてその場に存在しているわけですね。では、そういった目的を果たすのに必要なものは何かということをディープラーニングや機械学習を通じて実装してしまおうということです。これが、ASUKARU(アスカル)のこのWEBサイトサポートの大目玉ということです。

 

 

 

実は今日は別のお話(笑

 

上記で必死になって自社サービスの説明をしてきましたが、実は本日は全く違うお話です(笑

関連はしてますけどね。

 

Google検索結果
Google検索結果

こちらは、言わずと知れたGoogleのアクセス解析(アナリティクス)です。

このブログサイトではなくて、当社の方で運営を任されているWEBサイト(ブログサイト)の一つになります。今回は許可をいただきまして、ここに掲載、ご紹介をさせていただいております。

現状としましては、結構な数字を叩き出しておりますが、実は以前は1日30件程度のサイトでした。本当にWEBサイトの運営というのはやり方次第で化けます。

今でこそ、安定して3桁、多い時には4桁のアクセス(1日あたり)を出すようになりましたが、ここまで来るのに結構な努力をしてまいりました。当初は大幅なデザインの変更、検索index関係の設定、その他初歩的なところを改修・改善する必要がありました。

今回は、こちらのサイトで行われたことのご紹介です。

 

 

何もしていないが、すごいチャンス

 

実は、WEBサイトやホームページの運営というのは、何もしていないということが最大のチャンスなのです。

誰も知らない、あるいは、まだ知っている人が少ない。というのは本当にチャンスです。もしろWEBサイトやホームページをこれから持とうと思っていられるのであれば、最大のチャンスだと思ってください。

WEBサイトやホームページを運営していると、数の多少は色々あると思いますが、それでも認知度が高くなることがあるでしょう。人の目に触れる機会も多くなります。そうすると、実は簡単には次の展開ができなくなるのです。独自ドメインの移管作業を行う時にはなおのこと問題です。エンジニアの方や、システムについての知識があれば問題は少ないかと思いますが、例えば単純にPHPなどでheader関数を使用して別ページに飛ばす処理をしている時には、そこで与えられる引数(args: アーギュメント)に注意をしてください。

 

上のサイトでは、未だ認知度が低かったので体裁の変更などを行っても離反の可能性が非常に低いものでした。WEBサイトやホームページの運用では、どの程度の認知度にあるかで出来ること出来ないことがあります。

 

タグの適正な設置

ワードプレスなどでブログをしていても、何をしていても、タグと言われるもので記述をされています。必ずしもHTMLタグということに限りません。XMLなどもそうです。

ただし、どのようなマークアップ言語を使用するにしても、きちんとしたタグで記述をされていることが大事です。

これは2017年のGoogleの検索エンジンの方針発表でも言及をされています。余談ですが、我々Pythonエンジニアの間では、大体のWEBサイトやホームページなどはタグが壊れているという認識です。

きちんとしたタグでブログを表現することが大事ですね。

上記のサイトも実はタグ構造が壊れていました。もったいないです。ただ、無理もありません。ブログを書くのはHTMLを記述できる人ではないからです。ブログ記事をかける人が必ずしもHTMLをマークアップすることができるとは限りませんからね。そこで、その時使用していたブログ記事を書くシステムの内部をいじりました。こういうのをカスタマイズと呼びますが、要は適正なタグを記述できるように元々あるシステムを改善させるわけです。

 

スニペットの対応

 

スニペットってご存知でしょうか。これを設定することでGoogleでの検索に非常に有意義なデータを与えることができます。ぜひ、設定することをお勧めします。

 

 

細かいことは山ほどある

細部になるのですが。

記事の文字数、文字の大きさ、1ページとして表示されるページの中で自分が表現したい(出力したい)文字の数などを調査してみてください。

最後の自分が出したい文字の1ページに置ける文字数は、ブラウザにページが表示されたあとで、Windowsの方は「コントロールキー+F」Macの方は「Command+F」で表示される検索フォームの中に文字を入れるとヒット数を算出してくれます。

また、WEBブラウザのF12キーを使用するとデベロッパーツールが表示されます(もしかしたらお使いのWEBブラウザによって名前が異なるかもしれません。私はGoogleのChromeを使用しています)ので、そこでNetWorkやConsole画面をみて不必要なエラーが出ていないかをチェックしてください。

特にNetworkは、各コンテンツの表示スピードを出してくれるので、現在のGoogleの検索エンジン対策・つまりユーザーさんがストレスなく見ることができるWEBサイト、ホームページ制作には欠かせないものと思われます。

 

 

さて、述べたいことは山々ですが時間との関係でここまでにしておきます。今後このページは編集をして行こうと思いますので、いつかのタイミングで再度みられた時には表示が変わっているかもしれません。

 

それでは、今日も明日も、さらに高みを目指して張り切っていきましょう!

 

佐賀県神埼市でWEBシステム、AI、IoT、IOS、Androidアプリ開発

-*– ASUKARU –*-アスカル

TEL 0952-60-2693

Email asukaru2014@icloud.com

Adress 〒842-0002 佐賀県神埼市田道ヶ里2176-13

jQueryでチェックボックスの値を配列に格納・削除する方法

どっがーん!!!

佐賀県神埼市は非常に強い夕立(昼ダチ??)をいただきました。久しぶりに雷雨。明日は晴れて欲しいです。また、台風も来ていますね。現在も神埼市は大雨です。

佐賀県は全体的に平野なので夕立などは非常に激しく、稲光も当然のごとく空から地面に突き刺さります。容赦ない感じがもともと大分県民だった私には驚きでした。私の地元の大分県では、雷音だけでも相当珍しいのです。それが稲光が激しいのって、半端ではありません。

 

ところで、表題の件ですが、jQueryでチェックボックスの値を配列に格納するのはよくあること。けれども、チェックしてchecked状態になっているチェックボックスのチェックを外した時に、そのデータを操作するというものはあまり見かけませんでした。

そこで、今日はこちらを準備しました。

jQueryでチェックボックスの値を配列に格納・削除する方法

 

いくつか前提にしなければならないことがあるのですが、チェックボックスの実装イメージとしては、下記写真のような感じです。

複数のチェックボックスの値を取得・削除する方法|| 佐賀県神埼市アスカル

 

お気付きの方は。これがEC-CUBEであるということを察知されたことでしょう。

それはいいのですが、要はこのようにデーターベースに登録されている情報をIDなどの主キーを一緒に取得してきて吐き出している状態です。この前提が抜けてしまうと思っていた挙動をしないということもあるかと思います。

そして、今回は結構な力技をも用います。

 

HTML側

まず、HTML(テンプレート側)ですが

<td rowspan="2">
    <input type="checkbox" name="direct_delivery" value="1" id="direct_delivery_<!--{$arrResults[cnt].c_id}-->"/><label for="direct_delivery_<!--{$arrResults[cnt].c_id}-->">1</label>
</td>

 

と、テーブルを作成して、inputタグのid部分にはここではc_idとしておきます。上のはEC-CUBEのものをそのままなので。テンプレートエンジンにSmartyが使用されているため初見の方には馴染みがないかもしれません。

実際に簡単なHTMLを記述するとなると、

<table>

<tr>

 <td>

  <input type="checkbox" value="1" id="order_<?php echo htmlspecialchars($id, ENT_QUOTES, 'utf-8'); ?> >1(任意値)

 </td>

</tr>

</table>

 

という具合になるかと思います。このIDのところがPOINTですね。

 

jQuery側

 

<script>
  var idArray = []; −❶
  $('#direct_delivery_<!--{$arrResults[cnt].c_id}-->').on('click',function(){ −❷
  if ( $(this).prop('checked') == true ) { −❸
    var idname = $(this).attr("id");
    idArray.push(idname);
    console.log(idArray);
 } else {
    var idname = $(this).attr("id");
    for(i=0; i<idArray.length; i++){ −❹
      if(idArray[i] == idname){
        idArray.splice(i, 1);
      }
    }
    console.log(idArray);
  }
});
</script>

 

jQuery側は、このようにまず❶の部分で空の配列を作っておきます。後々この配列の中へチェックボックスでチェックを入れたり外したりする時の値を入れていきます。

次に、イベント発生は❷の部分で、今回はチェックボックスのIDを用いて指定をしていきました。こちらもテンプレートエンジンとの関係で、IDの指定をするのに波括弧を使用しておりますが、適宜ID名を指定してください。なお、勘の良い人はこの時点で気づくかと思いますが、このc_idは、実際にはPHPのループ文の中で使用されます。そのため、この記述をそのままテンプレートの下に貼り付けると、展開されるコードが冗長になります

ここは各システム内部の話になるのでどのように書くかはそのシステムごとに異なるとしか言いようがないです。

 

特に、inputタグのvalue属性とID値とが関連している場合には、このようなコードを書く必要がないこともあると思います。

 

何れにしても、❸の部分で条件分岐をしているのですが、trueの時はチェックがされた時、falseはチェックが外された時です。それぞれ、初期値が空の配列の中にデーターを格納したり、削除したりしています。ところで、Pythonなどとは異なり、jQueryの世界では値で配列内の特定の値を削除するということが組み込み関数ではできないみたいです。

 

そのため、❹ループ処理を使って配列の中身を検索して該当するものを削除する処理を記述しています。

 

 

 

以上が、今回のjQueryを使用したチェックボックスのチェック状態に応じてデーターを取得する方法についての実装です。

先にも触れましたが、それぞれのシステムに応じて異なることになるので実装される際にはソースが適宜変更になると思いますので、その点だけご容赦ください。

 

 

神埼は大雨ですが

 

 

この大雨は明日まで継続するらしいです。でも、これでようやく梅雨明けかもしれないですね。

それでは、今後も開発頑張っていきましょう!

 

 

佐賀県神埼市でWEBシステム、AI、IoT、IOS、Androidアプリ開発

-*– ASUKARU –*-アスカル

TEL 0952-60-2693

Email asukaru2014@icloud.com

Adress 〒842-0002 佐賀県神埼市田道ヶ里2176-13

Twitterへのログイン方法

今日は雨の神埼市

 

こんにちは。

アスカルの代表です。

今日は二日ぶりの雨に、涼しい朝を迎えています。神埼の夏は、大分県の佐伯市蒲江のように涼しいわけではないのです。ただ、山、川はこちらの方が多いので、清流などでは最高に楽しい遊びができるというわけですね。

 

神埼クリークのバス釣りが楽しい

ところで、涼しい朝晩ですが、神埼のクリークにてバス釣りをしています。ただこれがばらしの連続で、スピナーベイトをぐるぐる巻いてきても、日中は後方からゆっくりと追いかけてくる程度です。

アタックしてきてくれるのはだいたい、夕方、早朝の2軸です。ショートバイトも多いので、対策は必要だと思います。

 

 

さて、そんな私ですが毎日PCの前でシステムを改修・開発しているのですけれども、Twitterなどは断然素人でした。適当なメールアドレスでアカウントを作ってしまっていたため、メールアドレスでのログインもできない状態。

そんな適当アドレスでTwitterにログインできなくなった方のため、別の方法でログインをしてみましょうということをここに残しておきます。

と言っても、単純に今後もこのことを忘れるであろう私の備忘録です(笑

 

Twitterログイン方法

  1. メールアドレス認証 まずは、メールアドレス認証ですがこれがもっとも単純かつ最適な方法ですよね。ただ、メールアドレスが変更されると、メールアドレス宛にメールが届かない、とか、人間の記憶も昔のメールアドレスを覚えられておけるほど性能の高いものではないので、記憶の欠如ということになってしまいます。
  2. アカウント名認証

 

そのため、アカウント名を使用してログインをすることができるということを知っておくと便利です。私の場合はこれでなんとか忘却してしまったアカウントにログインすることができました。

 

いずれもダメなときは

 

 

 

….

あきらめるより他ないかもしれません。

 

 

 

GCPでエラー表示 ERROR: (gcloud.app.deploy) INVALID_ARGUMENT: Your app may not have more than 15 versions. Please delete one of the existing versions before trying to create a new version.

GCPで次のようなエラーが出力されることがある。

ERROR: (gcloud.app.deploy) INVALID_ARGUMENT: Your app may not have more than 15 versions. Please delete one of the existing versions before trying to create a new version.

 

GCPでバージョンが多すぎるというエラー

 

これに対応するには、要は不要な過去のバージョンを削除していけばOKということ。

 

まずは、バージョンを確認してみよう。

gcloud app versions list

 

 

次に、過去のバージョンを削除しよう。

 

gcloud app versions delete バージョン

 

最後にもう一度、アプリのデプロイをすればOK!

gcloud app deploy