在通过curl请求http获取response header时, 发现字符串拼接一个问题。
比如以下程序:
hadoop@1:~$ ct=$(curl -s -I http://www.baidu.com | grep Content-Type | awk '{print $2}')
hadoop@1:~$ echo $ct
text/html
hadoop@1:~$ echo $ct"_postfix"
_postfixl
最后一行输出竟然是: _postfixl
,而不是期待的text/html_postfix
细看结果应该是_postfix
直接覆盖了text/html
前面的内容。
http header是以\r\n
作为行分割符,与echo机制有什么冲突?
原因未解, 不过找到这样一种替代方法(如test.sh):
shopt -s extglob # 识别正则,用于后面去掉空格
function grepCT()
{
while IFS=':' read key value; do
# 去掉"value"内的空格
value=${value##+([[:space:]])}; value=${value%%+([[:space:]])}
case "$key" in
Server) SERVER="$value"
;;
Content-Type) CT="$value"
;;
HTTP*) read PROTO STATUS MSG <<< "$key{$value:+:$value}"
;;
esac
done < <(curl -sI $1)
echo $CT
}
ct=$(grepCT http://www.baidu.com)
echo $ct"_postfix"
执行shell文件:
hadoop@1:~$ bash test.sh
text/html_postfix
原文链接:https://www.f2er.com/bash/389969.html