PHP模型对应表字段注释属性快速生成

背景 以下内容基于thinkphp5.1框架和phpstrom编辑器进行说明 php web项目业务开发中绝大部分都是使用MVC结构的框架,在添加和更新数据时基本都支持实例化模型对象后赋值并保存。比如: $user = new User; $user->name = 'test'; $user->email = 'test@qq.com'; $user->save(); 其中name和email都对应user表的字段。这里编辑器不知道User表的表字段也就无法自动提示,意味着你要记住表的字段或者一边看表一边进行开发。 模型字段注释 针对上面的情况可以在User模型类中添加user表的字段注释来实现自动提示,开发时只需要记得字段大概的名称或者去User模型类中看注释即可知道表的结构。 <?php namespace app\user\model; use think\Model; /** * Class User * @property int member_id 主键 * @property varchar name 会员名称 * @property varchar email 邮箱 * @property varchar member_role 用户角色 * @property char passwd 密码 * @property int add_time 添加时间 * @property int update_time 最后一次修改时间 * @package app\user\model * @author jianghongjie */ class User extends Model { // 定义主键 protected $pk = 'member_id'; //开启自动时间戳 protected $autoWriteTimestamp = true; // 创建时间 protected $createTime = 'add_time'; // 更新时间 protected $updateTime = 'update_time'; } 快速生成模型字段注释 当表的字段很多或者表很多时写注释也很费时间和精力,使用下面的sql可以快速生成一个表的模型字段注释 ...

October 14, 2020 · 1 min · 152 words · 姜红杰

PHP json字符串解析中的引号问题

背景 json字符串的解析非常常见,但是php中单双引号含义不同以及各种字符串处理函数对json字符串的处理常常会导致json_decode()函数解析失败。这里借着工作中遇到的一个问题整理一下相关的知识点,做个沉淀。 php中的单双引号 区别 单引号中的内容会被认为就是纯文本。双引号中的内容则会经过解析,其中的变量、斜杠转义符等会被处理为对应的值。 关于用法 在php以前的版本中使用单引号处理速度比使用双引号速度要快,但是php7以后两者已经没有区别。对于需要进行变量替换的字符串只能使用双引号,对于纯字符串鸟哥在文章中还是建议大家使用双引号,理由是C/C++中双引号表示字符串以及HTML中属性值需要使用双引号包裹,与别的语言习惯保持一致。 问题说明 解析一个前端通过post form表单提交过来的json字符串,但是一直报json_decode()返回NULL,调用ljson_last_error()返回4,调用json_last_error_msg()返回Syntax error,但是json字符串能够被在线的json解析器正确处理。 排查 前端输入的字符串如下 [{"name":"测试添加车主","mobile":"13322232214"},{"name":"测试添加车主2","mobile":"13322232215"}] 将接收到的字符串使用var_dump()打印出来 string '[{\"name\":\"测试添加车主\",\"mobile\":\"13322232214\"},{\"name\":\"测试添加车主2\",\"mobile\":\"13322232215\"}]' (length=124) 打印出的字符串是单引号包含并且内部包含了转义字符串\" 将字符串复制出来,使用双引号包裹在进行解析 <?php $str = "[{\"name\":\"测试添加车主\",\"mobile\":\"13322232214\"},{\"name\":\"测试添加车主2\",\"mobile\":\"13322232215\"}]"; var_dump($str); $array = json_decode($str, true); var_dump($array); var_dump(json_last_error()); var_dump(json_last_error_msg()); 测试结果如下 PS D:\php\WWW> php .\test.php string(108) "[{"name":"测试添加车主","mobile":"13322232214"},{"name":"测试添加车主2","mobile":"13322232215"}]" array(2) { [0]=> array(2) { ["name"]=> string(18) "测试添加车主" ["mobile"]=> string(11) "13322232214" } [1]=> array(2) { ["name"]=> string(19) "测试添加车主2" ["mobile"]=> string(11) "13322232215" } } int(0) string(8) "No error" 这里可以观察到打印出来的json字符串被双引号包裹,并且字符串内部的转义字符\"已经被处理为",json_decode()函数也可以正确解析该json。因此这里可以确定问题就是接收到字符串内部含有转义字符\"但是外部不是使用双引号包裹的。 解决 追了一下源代码发现由于安全原因所有的输入都经过addslashes()函数处理防止sql注入,这里使用stripcslashes()函数去掉json字符串中的反斜杠就解决了该问题。 总结php json_encode喊出解析json字符串中的引号问题 内层的索引和值必须是双引号 外层是单引号时,内层的双引号不需要转义(不能是\",必须是") 外层是双引号时,内层的双引号需要转义(不能是",必须是\") 参考文章 鸟哥PHP单引号和双引号的区别 学知无涯php单引号和双引号的区别与用法 隐藏之海PHP json_decode JSON_ERROR_SYNTAX 错误详解 有心故我在php单引号和双引号的区别与用法

September 19, 2019 · 1 min · 82 words · 姜红杰