例のアレ
学校の講義で下のスライドのものを作りました。
これを見てください。
ナルトス
キ―――
Azure Virtual MachineでLet's Encryptを使おう!
かなりくだらない内容なので見なくてもいいです。あっている自信もないです。
適当に書いているので、その気分がなったら修正します。
PythonとそのフレームワークであるFlaskでLineBotを作ろうと思い、運用のためにMicrosoft AzureのVirtual MachineでUbuntu16.04 LTSを新規作成し、NginxやらPython3系用にpyenvやらあれやこれをどんどん入れました。
で、LineBotは通信のためにHTTPS通信でないとダメみたいなので、SSL証明書が必要なわけです。 opensslでも良かったのですが、もっと簡単にしたいなぁと考え、Let's Encryptを使おうと思いました。
以下経緯
( ^o^)SSL証明書を手に入れよう!
( ˘⊖˘) 。o(まてよ?先にcloudapp.netが使えるのか調べるべきでは?)
|Azure support (cloudapp.net) - Let's Encrypt Community Support| ┗(☋` )┓
三 ( ◠‿◠ )☛まず独自ドメインを手に入れるべきだぞ
▂▅▇█▓▒░(’ω’)░▒▓█▇▅▂うわあああああああああああああああああああ"
普通最初に気づくべきでしたね。
とてもつらい思いをしました。
千円なくしました。
暑い日
我が家は8月あたりにならないとクーラーを使わないので、ベッドで寝るときとても苦労します。
なので今日みたいな日は氷枕が手放せません。
ストップ温暖化
PDOで起きた問題
- 学校の講義でPDOを使う機会があり、かなり苦しめられたのでメモ代わりに残します。
- 解決できませんでした。
JavaScriptとPHPとSQLを使ってデータベースの内容を非同期通信でウェイ!って表形式で表示する内容なのです。
コード
<?php // 省略 // 追記部分 if ($_POST['id'] == null && $_POST['name'] != null && $_POST['address'] != null && $_POST['email'] != null) { $name = $_POST['name']; $address = $_POST['address']; $email = $_POST['email']; $stmt = $pdo -> prepare("INSERT INTO ".table."(name, address, email) VALUES (?, ?, ?)"); $stmt->bindParam(1, $name, PDO::PARAM_STR); $stmt->bindParam(2, $address, PDO::PARAM_STR); $stmt->bindParam(3, $email, PDO::PARAM_STR); $stmt->execute(); $stmt = $pdo->prepare("SELECT * FROM ".table); $stmt -> execute(); $result = $stmt->fetchALL(PDO::FETCH_ASSOC); } // この後、$resultをjson_encodeしてechoで出力する ?>
id以外テキストボックスに何かしらの文字が書かれている場合、INSERT文で挿入し、その後SELECT文で全件取得するという内容です。 何も考えずにそのまま実行したところ、表が表示されない・・・
要素を検証したところ
Uncaught TypeError: Cannot read property 'insertCell' of undefined
は?
どうやら連想配列を要素とした配列として返すはずなのに、挿入した内容のみをresponseされたせいで、存在しないよってエラー吐いてるみたいです。 一応追加自体は出来ていますが、モヤモヤするので直します。
SAの方とあれこれ試してみるも結局できない。 仕様か?と悩み始めたところで
PDOStatement::closeCursor() 使うのでは?
とのアドバイスを受け修正。
PHP: PDOStatement::closeCursor - Manual
<?php // 省略 // 追記部分 if ($_POST['id'] == null && $_POST['name'] != null && $_POST['address'] != null && $_POST['email'] != null) { $name = $_POST['name']; $address = $_POST['address']; $email = $_POST['email']; $stmt = $pdo -> prepare("INSERT INTO ".table."(name, address, email) VALUES (?, ?, ?)"); $stmt->bindParam(1, $name, PDO::PARAM_STR); $stmt->bindParam(2, $address, PDO::PARAM_STR); $stmt->bindParam(3, $email, PDO::PARAM_STR); $stmt->execute(); $stmt->closeCursor(); $stmt = $pdo->prepare("SELECT * FROM ".table); $stmt -> execute(); $result = $stmt->fetchALL(PDO::FETCH_ASSOC); } // この後、$resultをjson_encodeしてechoで出力する ?>
これだと思いながら実行したところ
Uncaught TypeError: Cannot read property 'insertCell' of undefined
もう打つ手がなかったので、$pdoをnullにするという暴挙に出ました。
<?php // 省略 // 追記部分 if ($_POST['id'] == null && $_POST['name'] != null && $_POST['address'] != null && $_POST['email'] != null) { $name = $_POST['name']; $address = $_POST['address']; $email = $_POST['email']; $stmt = $pdo -> prepare("INSERT INTO ".table."(name, address, email) VALUES (?, ?, ?)"); $stmt->bindParam(1, $name, PDO::PARAM_STR); $stmt->bindParam(2, $address, PDO::PARAM_STR); $stmt->bindParam(3, $email, PDO::PARAM_STR); $stmt->execute(); $stmt->closeCursor(); $pdo = null; $pdo = new PDO('mysql:host='.host.';dbname='.dbname,user,pass, $options); $pdo -> setAttribute(PDO::ATTR_ERRMODE, PDO::ERRMODE_EXCEPTION); $stmt = $pdo->prepare("SELECT * FROM ".table); $stmt -> execute(); $result = $stmt->fetchALL(PDO::FETCH_ASSOC); } // この後、$resultをjson_encodeしてechoで出力する ?>
祈るような気持ちで実行したところ
Uncaught TypeError: Cannot read property 'insertCell' of undefined
結局
JavaScript側でどうにかしました。 結局できなかったのは自分ができないだけなのか、PDOの仕様なのか分からずじまいでした・・・
最後に
すごいHaskell みんなで学ぼう
友達とみんなですごいH本を読みながらHaskellの勉強会やり始めました。
頑張ります!