node跨域请求方法小结
网络编程
本文介绍了node跨域请求,主要介绍了两种方法,一种是jsonp,另一种res.wirteHead,具体如下:
第一种:jsonp
参看用nodejs实现json和jsonp服务
第二种:res.wirteHead
node部分
var http = require('http') var url = require('url') var querystring = require('querystring') var port = 9000 var jsonData = { 'name': 'xiaohong', 'job': 'daboss' } http.createServer(function (req, res) { // var pathStr = url.parse(req.url) res.writeHead(200, { 'Content-Type': 'application/json;charset=utf-8', 'Access-Control-Allow-Credentials': true, 'Access-Control-Allow-Origin': '*' }) var type = req.method; if (type == 'GET') { res.end(JSON.stringify(jsonData)) } else if (type == 'POST') { var str = ''; req.on('data',function(chunk){ str += chunk; }) req.on('end',function(){ var data = querystring.parse(str) console.log(data) if(data.name == "" || data.job == ""){ res.end(JSON.stringify({'success':true,msg:'填写有误'})) }else{ res.end(JSON.stringify({'success':false,msg:'添加成功'})) } }) } }).listen(port, function () { console.log('server is runing at port ' + port) })
重点部分是添加响应头信息
res.writeHead(200, { 'Content-Type': 'application/json;charset=utf-8', 'Access-Control-Allow-Credentials': true, 'Access-Control-Allow-Origin': '*' //可以是*,也可以是跨域的地址 })
在ajax里不需要做任何特殊处理
dataType仍旧是json
html部分
<!DOCTYPE html> <html lang="en"> <head> <meta charset="UTF-8"> <meta name="viewport" content="width=device-width, initial-scale=1.0"> <meta http-equiv="X-UA-Compatible" content="ie=edge"> <title>Document</title> </head> <body> <a class="click" href="javascript:get_jsonp()" rel="external nofollow" >click me</a> <p class="result"></p> <label>姓名:</label> <input class="name" type="text" /> <label>职位:</label> <input class="job" type="text"> <a class="add" href = "javascript:add()">添加</a> <p class="msg"></p> <script src="http://code.jquery.com/jquery-latest.js"></script> <script> function get_jsonp() { $.ajax({ type: 'get', dataType: 'json', url: 'http://localhost:9000', success: function (data) { $('.result').html('my name is ' + data.name) }, error: function (err) { $('.result').html('出错了 ' + err.status) } }) } function add(){ $.ajax({ type:'post', url:'http://localhost:9000', dataType:'json', data:{ 'name':$(".name").val(), 'job':$(".job").val() }, success:function(data){ $('.msg').html(data.msg) }, error:function(err){ $('.msg').html('出错了'+err.status) } }) } </script> </body> </html>
以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持积木网。
node实现定时发送邮件的示例代码
本文介绍了node实现定时发送邮件的示例代码,分享给大家,具体如下:定时发送,可做提醒使用nodemailernodemailer是一款简单易用的基于于SMTP协议(或Amaz
ajax+node+request爬取网络图片的实例(宅男福利)
注:本文只讨论技术不涉及商业,如有侵权请告知,未经本人同意转载后果自负!本文是通过浏览器端ajax,node端request-json进行爬取尤果网部分图片资源
详谈Node.js之操作文件系统
1.同步方法与异步方法在Node.js中,使用fs模块来实现所有有关文件及目录的创建、写入及删除操作。,在fs模块中,所有对文件及目录的操作都可以使用
编辑:一起学习网
标签:本文,操作,方法,示例,发送邮件