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 · 姜红杰

Golang应用打包docker镜像并运行

使用gin框架起一个最基础的web服务来说明整个流程。 编写程序代码 main.go package main import "github.com/gin-gonic/gin" func main() { r := gin.Default() r.GET("/ping", func(c *gin.Context) { c.JSON(200, gin.H{ "message": "pong", }) }) r.Run("0.0.0.0:8080") // listen and serve on 0.0.0.0:8080 (for windows "localhost:8080") } 这里需要注意的是docker里面的host不能配置127.0.0.1或者192.168.0.1否则宿主机器将无法访问端口。所以这里服务启动时要绑定在0.0.0.0上。 编写Dockerfile文件 FROM golang:alpine MAINTAINER JiangHongJie "jhj767658181@gmail.com" # docker中的工作目录 WORKDIR $GOPATH/src/gin_docker # 将当前目录同步到docker工作目录下,也可以只配置需要的目录和文件(配置目录、编译后的程序等) ADD . ./ # 由于所周知的原因,某些包会出现下载超时。这里在docker里也使用go module的代理服务 ENV GO111MODULE=on ENV GOPROXY="https://goproxy.io" # 指定编译完成后的文件名,可以不设置使用默认的,最后一步要执行该文件名 RUN go build -o gin_docker . EXPOSE 8080 # 这里跟编译完的文件名一致 ENTRYPOINT ["./gin_docker"] 构建docker镜像 sudo docker build -t gin_docker . 构建完成查看镜像列表 vagrant@homestead:~/go_project/gin_docker$ docker image ls REPOSITORY TAG IMAGE ID CREATED SIZE gin_docker latest ed64de3e98e9 2 hours ago 469MB logforce latest 3cfe19164260 3 hours ago 511MB <none> <none> d20ebc82d1e6 6 hours ago 810MB <none> <none> c19c1e8968e1 6 hours ago 828MB golang alpine 30df784d6206 2 weeks ago 370MB 启动容器 vagrant@homestead:~/go_project/gin_docker$ docker run --name gin_docker -p 8080:8080 -d gin_docker ae97da70bc94a4c9a235f44a7d12030b283a2fabd56fc2be1a70ffef3a805c71 vagrant@homestead:~/go_project/gin_docker$ docker container ls CONTAINER ID IMAGE COMMAND CREATED STATUS PORTS NAMES ae97da70bc94 gin_docker "./gin_docker" 24 seconds ago Up 22 seconds 0.0.0.0:8080->8080/tcp gin_docker 访问服务 vagrant@homestead:~/go_project/gin_docker$ curl 127.0.0.1:8080/ping {"message":"pong"} 参考文章 使用 docker build 时 下载 golang.org/x 包失败

August 5, 2020 · 1 min · 171 words · 姜红杰

Golang Printf函数副词参数列表

Printf函数副词参数列表 General %v 以默认的方式打印变量的值 %T 打印变量的类型 Integer %d 整型的十进制表示 %+d 带符号的整型,fmt.Printf("%+d",255)输出+255 %q 打印单引号 %o 不带0的八进制 %#o 带0的八进制 %x 小写的十六进制 %X 大写的十六进制 %#x 带0x的十六进制 %U 打印Unicode字符 %#U 打印带字符的Unicode %b 打印整型的二进制 Integet width %5d 表示该整型最大的长度为5 %-5d 则相反,打印结果会自动左对齐 %05d 会在数字前面补0 Fload %f(=%.6f) 6位小数点 %e(=%.6e) 6位小数点(科学计数法) %g 用最少的数字来表示 %.3g 最多3位数字来表示 %.3f 最多3位小数来表示 String %s 正常输出字符串 %q 字符串带双引号,字符串中的引号带转义符 %#q 字符串带反引号,如果字符串内有反引号,就用双引号代替 %x 将字符串转换为小写的16进制格式 %X 将字符串转换为大写的16进制格式 % x 带空格的16进制格式 String width %5s 最小宽度为5 %-5s 最小宽度为5(左对齐) %.5s 最大宽度为5 %-5.7 最小宽度为5,最大宽度为7(左对齐) %5.3 如果宽度大于3则截断 %05s 如果宽度小于5,就会在字符串前面补0 Struct %v 正常打印.比如:{sam{12345 67890}} %+v 带字段名称,比如:{name:sam phone:{mobile:12345 office:67890}} %#v 用Go的语法打印,例如:main.People{name:"sam",phone:main.Phone{mobile:"12345",office:"67890"}} Boolean %t 打印布尔值true或者false Pointer %p 带0x的指针 %#p 不带0x的指针

July 27, 2020 · 1 min · 94 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 · 姜红杰