当用response.end(‘登录’)响应数据为汉字时,到页面中会显示乱码,是因为
在服务器默认发送的数据,其实是 utf-8编码的内容
但是浏览器不知道你是utf-8编码的内容
浏览器在不知道服务器响应内容的编码的情况下,会按照操作系统的默认编码去解析
中文操作系统默认是 gbk
解决方法:正确告诉浏览器我给你发送的内容是什么编码的
在http协议中 ,Content-Type就是用来告知对方我给你发送的数据是什么类型
不同文件类型对应的Content-Type
解决方法:
在响应数据返回汉字时,添加代码段:
//text/plain是普通文本
response.setHeader('Content-Type','text/plain; charset=utf-8');
例如:
var http=require('http');
var server=http.createServer()
//request 请求事件处理函数,需要接收两个参数:
//Request 请求对象(请求对象可以用来获取客户端的一些请求信息,例如请求路径)
//Response 响应对象(响应对象可以用来给客户端发送响应消息)
server.listen(4000,function(){
console.log('服务器启动成功,可通过http://127.0.0.1:4000/ 来进行访问');
});//数字随便写 只要没被占用
server.on('request',function(request,response){
//text/plain是普通文本
response.setHeader('Content-Type','text/plain; charset=utf-8');
console.log('收到客户端请求,请求路径为:' + request.url);
if(request.url=='/') //啊啊啊 一定要注意是双等或三等 不要写成单等
{
response.write('index');
//告诉客户端,我的话说完了,你可以呈递给用户了
response.end();
//也可直接将两句写为 response.end('index');
}
if(request.url=='/login')
{
response.write('登录');
//告诉客户端,我的话说完了,你可以呈递给用户了
response.end();
}
if(request.url=='/register')
{
response.write('注册\n');
//告诉客户端,我的话说完了,你可以呈递给用户了
response.end();
}
if(request.url=='/haha')
{
response.write('哈哈哈');
//告诉客户端,我的话说完了,你可以呈递给用户了
response.end();
}
})