CSRF 攻击
CSRF:(Cross-site request forgery),中文名称,跨站请求伪造。也被称为 one click attack/session riding。
可以这么理解 CSRF 攻击:攻击者盗用了你的身份,以你的名义发送恶意请求。
CSRF:(Cross-site request forgery),中文名称,跨站请求伪造。也被称为 one click attack/session riding。
可以这么理解 CSRF 攻击:攻击者盗用了你的身份,以你的名义发送恶意请求。
前几天在测试 HttpServletRequest 获取参数的时候使用 Postman 这个工具发送请求的时候遇到了问题,Post 请求不管怎么发送,始终拿不到数据,Get 请求一点问题都没有。查了好几次终于明白是因为 Content-type 的问题。
HTTP/2 源自 SPDY/2
二进制协议的解析效率高,几乎没有解析代价。
二进制协议没有冗余字段,占用带宽少。
压缩及 https 技术弱化了文本协议的价值。
有的时候 netstat 查看会看到非常多的 tcp 连接状态为 time wait 或者 close wait。这两个问题都不算难处理,这里分别解释一下两个问题出现的原理。
首先理一下 tcp 挥手时的状态转换。
go 语言通过 goroutine 提供了并发编程支持,goroutine 是 go 运行库的功能,而不是操作系统线程实现的,goroutine 可以被理解成一个用户态的线程。
动词 | 示例 | 含义 |
---|---|---|
%v | 默认格式输出,当输出结构体时,扩展标志(%+v)会添加字段名 | |
%#v | 值的 Go 语法表示 | |
%T | 值的类型的Go语法表示 | |
%% | 百分号 |
动词 | 示例 | 含义 |
---|---|---|
%t | true | 单词 true 或 false |
动词 | 示例 | 含义 |
---|---|---|
%b | 表示二进制 | |
%c | 该值对应的unicode码值 | |
%d | 表示为十进制 | |
%o | 表示为八进制 | |
%q | 该值对应的单引号括起来的go语法字符字面值,必要时会采用安全的转义表示 | |
%x | 表示为十六进制,使用a-f | |
%X | 表示为十六进制,使用A-F | |
%U | 表示为Unicode格式:U+1234,等价于"U+%04X" |
动词 | 示例 | 含义 |
---|---|---|
%b | 无小数部分、二进制指数的科学计数法,如-123456p-78 | |
%e | 科学计数法,如-1234.456e+78 | |
%E | 科学计数法,如-1234.456E+78 | |
%f | 有小数部分但无指数部分,如123.456 | |
%F | 等价于%f | |
%g | 根据实际情况采用%e或%f格式(以获得更简洁、准确的输出) | |
%G | 根据实际情况采用%E或%F格式(以获得更简洁、准确的输出) |
对于浮点数,宽度设置输出总长度;精度设置小数部分长度(如果有的话),除了%g/%G,此时精度设置总的数字个数。例如,对数字123.45,格式%6.2f 输出123.45;格式%.4g输出123.5。
Delve 是一个 Golang 的调试工具,比 GDB 要好用很多,能支持协程的调试。使用的时候可以直接运行程序调试,也可以 attach 到一个正在运行中的程序。
Delve 的安装很简单,它本身也是 go 写的。
Go 语言推荐测试文件和源代码文件放在一起。测试文件以 “_test.go” 结尾(这样在 go build 的时候才不会被包含)。
example/
|-- biz.go
|-- biz_test.go
普通测试用例的方法以 Test 开头,参数为 t *testing.T
在操作 linux 的使用,使用 ssh 连接终端是很常见的事情,但是有几个问题
sudo apt-get install tmux
sudo apt-get update
sudo apt-get install -y libevent-dev libncurses-dev make
cd /tmp
wget https://github.com/tmux/tmux/releases/download/2.7/tmux-2.7.tar.gz
tar xvzf tmux-2.7.tar.gz
cd tmux-2.7/
./configure && make
sudo make install
cd ..
rm -rf ./tmux-2.7*
有时需要手动在当前目录下复制 tmux 二进制文件。
Command Line Tools 是苹果的一个小型独立包,适用于 macOS,为终端扩展了额外的功能。包括但不限于:svn、git、make、GCC、clang、perl、size、strip、strings、libtool、cpp、what、codesign以及其他很多能够在Linux中找到的命令。