ブラウザバック時にFORM送信された値が保持されない
概要
取り扱っているシステムでブラウザバック時にFORM送信された値が保持されない箇所があったので原因を調査した。
状況
選択肢1と選択肢2が存在し以下の流れでブラウザバックをする。
- 選択肢1の値はサーバサイドで作られる
- 選択肢1の選択に追従して選択肢2の値をXHR(Ajax等)で取得して変更する(初期表示の際は選択肢1の値を元にXHRでデータ取得をする)
- 選択肢2を選択する
- ブラウザバック
そうすると選択肢1ではFORMで送信した値が保持されるが、選択肢2では値が保持されない。 気づく人はこの時点でオチがわかるかもしれないが原因は以下。
原因
ブラウザバック時に選択肢1と選択肢2で選択した値が、前画面の選択肢1と選択肢2にセットされる。 選択肢1のデータはサーバサイドで作られるため、view上には選択肢1の収まるデータが存在するためブラウザバックしても値は保持される。 この際、選択肢2のデータリストは選択肢1の値をもとにXHRで取得されるため、選択肢2の初期のデータリストは空っぽである。初期状態の選択肢2のデータリストが空のため、ブラウザバック時に選択肢2が収まる場所がないため、選択肢2の値が消滅してしまう。
対策
- 選択肢2に入りうる値をサーバサイド側でviewに詰め込む
- 選択肢2の変更に追従するhiddenタグを用意する。選択肢2の値が変更されたらhiddenの値を利用して初期状態をセットしてあげる
MySQLを動かすことができない場合の対処方法
概要
以下のエラーが発生したためメモ。
ERROR 2002 (HY000): Can't connect to local MySQL server through socket '/var/run/mysqld/mysqld.sock' (2)
詳細
mysql起動
「mysql」コマンドを実行しても上記のエラーが発生して先に進まない
service mysql start
エラーログをみる
エラーログは以下の場所へ出力されている。
/var/log/mysql/error.log
エラーログを見てみるとソケットファイルを作成できなかったとわかる
Could not create unix socket lock file /var/run/mysqld/mysqld.sock.lock.
mysqlユーザに権限を与える
ソケットファイルが作れるようにmysqlユーザに権限を与える
sudo chown mysql:mysql /var/run/mysqld
以下のコマンドで動かせばOK
service mysql start
【Python】oduleNotFoundError: No module named '__builtin__'
概要
以下のエラーが発生したためメモ。Python3では__buildin__
が利用できない。
ModuleNotFoundError: No module named '__builtin__'
解決策
__buildin__
の代わりにbuiltins
を利用する。
# import __builtin__ ※これは使えない import builtins
# __builtin__.__import__(引数) ※これは使えない builtins.__import__(引数)
【Python】Python3でnew.instancemethodが使えない
概要
以下のエラーが発生したためメモ。
ModuleNotFoundError: No module named 'new'
調べてみるとPython3ではnewモジュールが利用できないみたい。
解決策
以下のように行うことで、解消できる。
# import new ※これは使用できない from types import MethodType as instancemethod
# new.instancemethod(いくつかの変数) ※これは使用できない instancemethod(いくつかの変数)
参考
【Python】TypeError: Unicode-objects must be encoded before hashing
概要
以下のエラーが出たためメモ。
TypeError: Unicode-objects must be encoded before hashing
解決策
文字列の末尾に.encode('utf-8')
を追記する。