国产探花免费观看_亚洲丰满少妇自慰呻吟_97日韩有码在线_资源在线日韩欧美_一区二区精品毛片,辰东完美世界有声小说,欢乐颂第一季,yy玄幻小说排行榜完本

首頁 > 開發(fā) > AJAX > 正文

node.js+Ajax實現(xiàn)獲取HTTP服務器返回數(shù)據(jù)

2024-09-01 08:32:56
字體:
供稿:網(wǎng)友
這篇文章主要介紹了node.js+Ajax實現(xiàn)獲取HTTP服務器返回數(shù)據(jù),講解的十分詳細,也給出了很多的實例,是篇非常不錯的文章,這里推薦給大家。
 
 

我們看一個HTML5頁面中通過AJAX請求的方式獲取HTTP服務器返回數(shù)據(jù)的代碼示例.由于我們把服務器的端口指定為1337,并將從端口為80的網(wǎng)站中運行HTML5頁面,因此這是一種跨域操作,需要在HTTP響應頭部中添加Access_Control_Allow_Origin字段,并且將參數(shù)指定為允許向服務器請求數(shù)據(jù)額域名+端口號(省略端口號時允許該域名下的任何端口向服務器請求數(shù)據(jù)),

靜態(tài)頁面:index.html(注:一定要放在服務器環(huán)境下,如果是win7系統(tǒng)的話,可以開啟IIS服務,并把頁面考過去直接運行這個頁面,)

 

復制代碼代碼如下:

<!DOCTYPE html>
<html>
<head lang="en">
    <meta charset="UTF-8">
    <title>node中的ajax請求(html5頁面)</title>
    <script type="text/javascript">
        function GetData(){
            var xhr=new XMLHttpRequest();
            xhr.open("GET","http://localhost:1337/",true);
            xhr.onreadystatechange=function(){
                if(xhr.readyState==4){
                    if(xhr.status==200){
                        document.getElementById("res").innerHTML=xhr.responseText;
                    }
                }
            }
            xhr.send(null);
        }
    </script>
</head>
<body>
<input type="button" value="獲取數(shù)據(jù)" onclick="GetData()" />
<div id="res">dsdf</div>
</body>
</html>

 

node代碼:

 

復制代碼代碼如下:

var http=require("http");
var server=http.createServer(function(req,res){
    if(req.url!=="/favicon.ico"){
        res.writeHead(200,{"Content-Type":"text/plain","Access-Control-Allow-Origin":"http://localhost"});
        res.write("你好啊!");
    }
    res.end();
});
server.listen(1337,"localhost",function(){
    console.log("開始監(jiān)聽...");
});

 

首先開啟服務:node server.js

啟動靜態(tài)頁面:

node.js+Ajax實現(xiàn)獲取HTTP服務器返回數(shù)據(jù)

點擊按鈕"獲取數(shù)據(jù)"

node.js+Ajax實現(xiàn)獲取HTTP服務器返回數(shù)據(jù)

如果大家覺得需要配置服務器環(huán)境太麻煩,可以借用編輯器的優(yōu)勢來做.

比如我用的是webstrom 8.0;

當我啟動頁面的時候,瀏覽器中顯示的是這個路徑:

node.js+Ajax實現(xiàn)獲取HTTP服務器返回數(shù)據(jù)

端口是63342.這個時候我們隊代碼做一些修改:

node的 server.js代碼:

 

復制代碼代碼如下:

var http=require("http");
var server=http.createServer(function(req,res){
    if(req.url!=="/favicon.ico"){
        res.writeHead(200,{"Content-Type":"text/plain","Access-Control-Allow-Origin":"http://localhost:63342"});
        //res.setHeader();
        res.write("你好啊!");
    }
    res.end();
});
server.listen(1337,"localhost",function(){
    console.log("開始監(jiān)聽...");
});

 

修改了"Access-Control-Allow-Origin"的值.

重新運行demo會發(fā)現(xiàn),達到同樣的效果

也可以通過res.seetHeader來單獨設置響應頭部.

可以將上面的res.writeHead()改成res.setHeader();

 

復制代碼代碼如下:

var http=require("http");
var server=http.createServer(function(req,res){
    if(req.url!=="/favicon.ico"){
        //res.writeHead(200,{"Content-Type":"text/plain","Access-Control-Allow-Origin":"http://localhost:63342"});
        res.setHeader("Content-Type","text/plain");
        res.setHeader("Access-Control-Allow-Origin","http://localhost:63342");
        res.write("你好啊!");
    }
    res.end();
});
server.listen(1337,"localhost",function(){
    console.log("開始監(jiān)聽...");
});

 

細心的同學可能發(fā)現(xiàn)了,利用setHeader的方法時,缺少了一個狀態(tài)碼,比如200.那么我們在使用res.setHeader的時候,如何來設置狀態(tài)碼呢?等會上代碼

ajax在服務器端返回的時候日期:

node.js+Ajax實現(xiàn)獲取HTTP服務器返回數(shù)據(jù)

我們可以在服務器端返回時,刪除這個字段.

設置res.sendData=false;

 

復制代碼代碼如下:

var http=require("http");
var server=http.createServer(function(req,res){
    if(req.url!=="/favicon.ico"){
        //res.writeHead(200,{"Content-Type":"text/plain","Access-Control-Allow-Origin":"http://localhost:63342"});
        res.statusCode=200;
        res.sendDate=false;
        res.setHeader("Content-Type","text/plain");
        res.setHeader("Access-Control-Allow-Origin","http://localhost:63342");
        res.write("你好啊!");
    }
    res.end();
});
server.listen(1337,"localhost",function(){
    console.log("開始監(jiān)聽...");
});

 

node.js+Ajax實現(xiàn)獲取HTTP服務器返回數(shù)據(jù)

設置了狀態(tài)碼,也屏蔽了日期信息.

res.getHeader(name)獲取我們設置的響應頭信息

res.removeHeader(name);刪除我們的頭信息.必須在我們的write方法發(fā)送數(shù)據(jù)之情被調(diào)用.

res.headersSent屬性是一個布爾值,當當響應頭已發(fā)送時,屬性值為true時;當響應頭未發(fā)送時,屬性值為false.

server.js代碼:

 

復制代碼代碼如下:

var http=require("http");
var server=http.createServer(function(req,res){
    if(req.url!=="/favicon.ico"){
        if(res.headersSent)
            console.log("響應頭已發(fā)送");
        else
            console.log("響應頭未發(fā)送");
        res.writeHead(200,{"Content-Type":"text/plain","Access-Control-Allow-Origin":"http://localhost:63342"});
        if(res.headersSent)
            console.log("響應頭已發(fā)送");
        else
            console.log("響應頭未發(fā)送");        
        res.write("你好啊!");
    }
    res.end();
});
server.listen(1337,"localhost",function(){
    console.log("開始監(jiān)聽...");
});

 

運行demo查看結果:

node.js+Ajax實現(xiàn)獲取HTTP服務器返回數(shù)據(jù)

res.write()方法是向客戶端發(fā)送數(shù)據(jù)的,其實他還有一個返回值.

當向客戶端發(fā)送的數(shù)據(jù)量比較小時或網(wǎng)速較快時,node總是將數(shù)據(jù)直接發(fā)送到操作系統(tǒng)的內(nèi)核緩存區(qū)中,然后從內(nèi)核緩存區(qū)中取出數(shù)據(jù)發(fā)送給對方.這個時候write會返回true.

當網(wǎng)速慢或數(shù)據(jù)量較大時,http服務器并不一定會立刻把數(shù)據(jù)發(fā)送給客戶端,node會把數(shù)據(jù)緩存在內(nèi)存中,并在對方可以接受數(shù)據(jù)的情況下將內(nèi)存中的數(shù)據(jù)通過操作系統(tǒng)的內(nèi)核發(fā)送給對方.這時的write返回false.

node.js+Ajax實現(xiàn)獲取HTTP服務器返回數(shù)據(jù)

可以設置test.txt的內(nèi)容多少來測試結果.

一個簡單的node+ajax效果就實現(xiàn)了.是不是很簡單呢?當然,想制作更加復雜的功能的話,我們還需要進一步的學習,以后我們慢慢來更新。


發(fā)表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發(fā)表
主站蜘蛛池模板: 临猗县| 托克托县| 康保县| 射阳县| 天门市| 广南县| 桓台县| 沙洋县| 栾川县| 孟津县| 体育| 肥城市| 山西省| 安龙县| 大埔区| 丹寨县| 湄潭县| 福贡县| 余干县| 肇源县| 连南| 横山县| 乐陵市| 黔江区| 和田市| 台山市| 盐山县| 新泰市| 阳东县| 阿勒泰市| 漳浦县| 济源市| 涪陵区| 莆田市| 洪湖市| 观塘区| 柳林县| 台江县| 边坝县| 昭苏县| 澳门|