導航:首頁 > 編程語言 > nodejs發送get請求

nodejs發送get請求

發布時間:2023-06-13 19:57:44

❶ nodejs中使用$.get 獲取html出現中文亂碼

npm install -g nodegrass //安裝此模塊使用
var gs = require('nodegrass');
gs.get('http://www.jd.com', function(data){
console.log(data);//將data輸出即使中文

}, 'gbk').on('error',funtion(err){
console.log(err);

});
可以查查nodegrass的說明 https://github.com/scottkiss/nodegrass

❷ nodejs搭建web伺服器就是這么簡單!

Node.js 是一個基於 Chrome V8 引擎的 javaScript 運行環境。 Node.js 使用了一個事件驅動、非阻塞式 I/O 的模型,使其輕量又高效。Node.js 的包管理器 npm,是全球最大的開源庫生態系統。(nodejs官網上的介紹),正如官網上介紹的那樣,nodejs確實很牛!怎麼個牛法?看看下面的代碼就知道了。

//引入http模塊

var http = require("http");

//設置主機名

var hostName = 飗.0.0.1'

//設置埠

var port = 8080;

//創建服務

var server = http.createServer(function(req,res){

res.setHeader('Content-Type','text/plain');

res.end("hello nodejs");

});

server.listen(port,hostName,function(){

console.log(`伺服器運行在http://${hostName}:${port}`);

});

短短幾行代碼就把一個簡單的web伺服器搭建完成了,為了驗證效果,我們在瀏覽器請求,結果如下

運行成功!

到此為止,一個web伺服器就建立成功了! 沒錯就是這么簡單,然後我們就可以寫個html界面愉快的玩耍了,哈哈哈!果斷的寫了一個html頁面來請求一下我們的web伺服器。

代碼簡單,點擊p獲取數據並將伺服器返回的數據展示。好了,我們運行一下demo.html文件,我擦來!居然出現了……

很明顯,通過jquery請求不到數據,這是因為跨域請求的原因。我們的web伺服器並不支持跨域請求,所以報錯了。解決方式:在伺服器的響應頭文件里加上如下代碼:

再次重啟伺服器,運行demo.html,顯示結果很是令人欣喜!

通常請求伺服器都會拼接參數的,最常用的就是get請求,post請求。很明顯,我們現在的代碼還不能支持。express框架很好的封裝了nodejs的http模塊,使我們用起來非常的簡單。

引入express :$ cnpm install express –save

使用方式變化不大,通過express()方法開啟服務,然後在通過get方法來設置匹配參數的路由,通過在回調函數的req中可以獲取請求參數和地址。post請求也是類似,不過有不同的是,post請求在獲取參數的時候要引入body-parser 中間件,用於處理 JSON, Raw, Text 和 URL 編碼的數據。

運行結果:

完整的get以及post請求就是以上了。下一篇文章會結果fs文件模塊介紹http是如何返迴文件的,敬請期待!!

學習從來不是一個人的事情,要有個相互監督的夥伴,想要學習或交流前端問題的小夥伴可以私信「學習」小明加群獲取2019web前端最新入門資料,一起學習,一起成長!

❸ 如何使用nodejs做爬蟲程序

作者:Mike Chen
鏈接:https://www.hu.com/question/31679802/answer/128390326
來源:知乎
著作權歸作者所有,轉載請聯系作者獲得授權。

首先樓主要使用nodejs作為語言或者平台來開發爬蟲是沒有任何問題的,反而nodejs的event io能夠讓你感覺到網路編程可以如此酣暢淋漓,一如http://nodejs.org 官網給出的http server 的例子,幾行代碼就能實現web服務,沒有apache 沒有tomcat也沒有iis,只要設置一個回調,監聽一個埠,你就可以使用瀏覽器訪問了。
其次,爬蟲是最明顯的IO密集型應用場景,顯然和擅長處理IO的nodejs是絕配,但是把它用好是需要一些功底的。如果你想要從頭開發,不藉助第三方框架,那麼你需要對nodejs中的event emitter 及 http 模塊有深入的了解,加上你的HTTP協議的知識,再到node平台中找到相應的實現方案,從而實現你要的功能。舉個例子,使用http模塊發送一個GET請求到網路,你需要弄清楚對req,也就是http.get的返回值,監聽什麼樣的事件,http的頭部信息和正文信息分別應該在什麼階段獲取。在python中方法很直白,簡簡單單的用urllib來open一個鏈接,接著read就算完事兒,寫到這里突然感覺可以理解之前那位仁兄認為的"不適合",也許是覺得node 不如python的直白,又或許只是對node的理解不夠到位,不好拿捏?
最後,如果樓主想要把node作為平台來開發爬蟲,我建議直接從開源框架入手,立刻做出一些可用的程序來給自己一些正反饋,然後再慢慢學習體會。

❹ 如何用nodejs指定時間訪問某個網站

Node.js為請求提供了更加簡便的方法。 該方法和 Http.request()的不同在於,該方法只以 GET 方式請求,並且會自動調用 req.end()來結束請求。

❺ get和post的區別,nodejs,use


  1. get是從伺服器上獲取數據,post是向伺服器傳送數據。


2 get是把參數數據隊列加到提交表單的ACTION屬性所指的URL中,值和表單內各個欄位一一對應,在URL中可以看到。post是通過HTTP post機制,將表單內各個欄位與其內容放置在HTML HEADER內一起傳送到ACTION屬性所指的URL地址。用戶看不到這個過程。
3 對於get方式,伺服器端用Request.QueryString獲取變數的值,對於post方式,伺服器端用Request.Form獲取提交的數據。
4 get傳送的數據量較小,不能大於2KB。post傳送的數據量較大,一般被默認為不受限制。但理論上,IIS4中最大量為80KB,IIS5中為100KB。
5 get安全性非常低,post安全性較高。
6 HTTP 定義了與伺服器交互的不同方法,最基本的方法是 GET 和 POST。事實上 GET 適用於多數請求,而保留 POST 僅用於更新站點。根據 HTTP 規范,GET 用於信息獲取,而且應該是 安全的和冪等的。所謂安全的意味著該操作用於獲取信息而非修改信息。換句話說,GET 請求一般不應產生副作用。冪等的意味著對同一 URL 的多個請求應該返回同樣的結果。完整的定義並不像看起來那樣嚴格。從根本上講,其目標是當用戶打開一個鏈接時,她可以確信從自身的角度來看沒有改變資源。 比如,新聞站點的頭版不斷更新。雖然第二次請求會返回不同的一批新聞,該操作仍然被認為是安全的和冪等的,因為它總是返回當前的新聞。反之亦然。POST 請求就不那麼輕鬆了。POST 表示可能改變伺服器上的資源的請求。仍然以新聞站點為例,讀者對文章的註解應該通過 POST 請求實現,因為在註解提交之後站點已經不同了
7 在FORM提交的時候,如果不指定Method,則默認為GET請求,Form中提交的數據將會附加在url之後,以?分開與url分開。字母數字字元原 樣發送,但空格轉換為「+「號,其它符號轉換為%XX,其中XX為該符號以16進製表示的ASCII(或ISO Latin-1)值。GET請求請提交的數據放置在HTTP請求協議頭中,而POST提交的數據則放在實體數據中;GET方式提交的數據最多隻能有1024位元組,而POST則沒有此限制

❻ nodejs 怎樣知道請求是get或post

一 express框架接收

app.get('/',function(req,res) { var url = req.query.url; var name = req.query.name; console.log(url, name);});
二 接收Get
1. get參數在req.url上
2. 使用url.parse將數據由字元串轉變為obj
index.js:

var http = require('http');var url = require('url');var util = require('util'); //req 請求信息 res返回信息http.createServer(function(req, res){ res.writeHeader(200, {'Content-Type':'text/javascript;charset=UTF-8'}); //狀態碼+響應頭屬性 // 解析 url 參數 var params = url.parse(req.url, true).query; //parse將字元串轉成對象,req.url="/?url=123&name=321",true表示params是{url:"123",name:"321"},false表示params是url=123&name=321 res.write("網站名:" + params.name); res.write("\n"); res.write("網站 URL:" + params.url); res.end(); }).listen(3000);
瀏覽器打開:
http://127.0.0.1:3000/?url=123&name=321
網頁顯示:

網站名:321網站 URL:123

❼ c#怎麼向nodejs的socket.io發送請求

1. 簡介

首先是Socket.IO的官方網站:http://socket.io

官網非常簡潔,甚至沒有API文檔,只有一個簡單的「How to use」可以參考。因為Socket.IO就跟官網一樣簡潔好用易上手。

那麼Socket.IO到底是什麼呢?Socket.IO是一個WebSocket庫,包括了客戶端的js和伺服器端的nodejs,它的目標是構建可以在不同瀏覽器和移動設備上使用的實時應用。它會自動根據瀏覽器從WebSocket、AJAX長輪詢、Iframe流等等各種方式中選擇最佳的方式來實現網路實時應用,非常方便和人性化,而且支持的瀏覽器最低達IE5.5,應該可以滿足絕大部分需求了。

2. 安裝部署

2.1 安裝

首先安裝非常簡單,在node.js環境下只要一句:

復制代碼
代碼如下:

npm install socket.io

2.2 結合express來構建伺服器

express是一個小巧的Node.js的Web應用框架,在構建HTTP伺服器時經常使用到,所以直接以Socket.IO和express為例子來講解。

復制代碼
代碼如下:

var express = require('express')
,
app = express()
, server = require('http').createServer(app)
, io
= require('socket.io').listen(server);
server.listen(3001);

若不使用express,請參考socket.io/#how-to-use

3. 基本使用方法

主要分為伺服器端和客戶端兩段代碼,都非常簡單。

Server(app.js):

復制代碼
代碼如下:

//接上面的代碼
app.get('/', function (req,
res) {
res.sendfile(__dirname + '/index.html');});

io.sockets.on('connection', function (socket) {
socket.emit('news', {
hello: 'world' });
socket.on('other event', function (data) {

console.log(data);
});
});

首先io.sockets.on函數接受字元串"connection"作為客戶端發起連接的事件,當連接成功後,調用帶有socket參數的回調函數。我們在使用socket.IO的時候,基本上都在這個回調函數裡面處理用戶的請求。

socket最關鍵的是emit和on兩個函數,前者提交(發出)一個事件(事件名稱用字元串表示),事件名稱可以自定義,也有一些默認的事件名稱,緊接著是一個對象,表示向該socket發送的內容;後者接收一個事件(事件名稱用字元串表示),緊接著是收到事件調用的回調函數,其中data是收到的數據。

在上面的例子中,我們發送了news事件和收到了other
event事件,那麼客戶端應該會有對應的接收和發送事件。沒錯,客戶端代碼和伺服器正好相反,而且非常相似。

Client(client.js)

復制代碼
代碼如下:

<script
src="/socket.io/socket.io.js"></script>
<script>
var
socket = io.connect('http://localhost');
socket.on('news', function
(data) {
console.log(data);
socket.emit('other event', {
my: 'data' });
});
</script>

有兩點要注意的:socket.io.js路徑要寫對,這個js文件實際放在了伺服器端的node_moles文件夾中,在請求這個文件時會重定向,因此不要詫異伺服器端不存在這個文件但為什麼還能正常工作。當然,你可以把伺服器端的socket.io.js這個文件拷貝到本地,使它成為客戶端的js文件,這樣就不用每次都向Node伺服器請求這個js文件,增強穩定性。第二點是要用var
socket =
io.connect('網站地址或ip');來獲取socket對象,接著就可以使用socket來收發事件。關於事件處理,上面的代碼表示收到「news」事件後,列印收到的數據,並向伺服器發送「other
event」事件。

註:內置默認的事件名例如「disconnect」表示客戶端連接斷開,「message」表示收到消息等等。自定義的事件名稱,盡量不要跟Socket.IO中內置的默認事件名重名,以免造成不必要的麻煩。

4. 其他常用API

1).向所有客戶端廣播:socket.broadcast.emit('broadcast message');

2).進入一個房間(非常好用!相當於一個命名空間,可以對一個特定的房間廣播而不影響在其他房間或不在房間的客戶端):socket.join('your
room name');

3).向一個房間廣播消息(發送者收不到消息):socket.broadcast.to('your room name').emit('broadcast
room message');

4).向一個房間廣播消息(包括發送者都能收到消息)(這個API屬於io.sockets):io.sockets.in('another room
name').emit('broadcast room message');

5).強制使用WebSocket通信:(客戶端)socket.send('hi'),(伺服器)用socket.on('message',
function(data){})來接收。

5. 使用Socket.IO構建一個聊天室

最後,我們通過一個簡單的實例來結束本篇。用Socket.IO構建一個聊天室就是50行左右的代碼的事情,實時聊天效果也非常好。以下貼出關鍵代碼:

Server(socketChat.js)

復制代碼
代碼如下:

//一個客戶端連接的字典,當一個客戶端連接到伺服器時,
//會產生一個唯一的socketId,該字典保存socketId到用戶信息(昵稱等)的映射
var
connectionList = {};

exports.startChat = function (io) {
io.sockets.on('connection',
function (socket) {
//客戶端連接時,保存socketId和用戶名
var socketId =
socket.id;
connectionList[socketId] = {
socket:
socket
};

//用戶進入聊天室事件,向其他在線用戶廣播其用戶名
socket.on('join', function
(data) {
socket.broadcast.emit('broadcast_join',
data);
connectionList[socketId].username =
data.username;
});

//用戶離開聊天室事件,向其他在線用戶廣播其離開
socket.on('disconnect', function
() {
if (connectionList[socketId].username) {

socket.broadcast.emit('broadcast_quit', {
username:
connectionList[socketId].username
});

}
delete connectionList[socketId];
});

//用戶發言事件,向其他在線用戶廣播其發言內容
socket.on('say', function (data)
{
socket.broadcast.emit('broadcast_say',{

username: connectionList[socketId].username,
text:
data.text
});
});
})
};

Client(socketChatClient.js)

復制代碼
代碼如下:

var socket =
io.connect('http://localhost');
//連接伺服器完畢後,馬上提交一個「加入」事件,把自己的用戶名告訴別人
socket.emit('join',
{
username: 'Username hehe'
});

//收到加入聊天室廣播後,顯示消息
socket.on('broadcast_join', function (data) {

console.log(data.username + '加入了聊天室');
});

//收到離開聊天室廣播後,顯示消息
socket.on('broadcast_quit', function(data) {

console.log(data.username + '離開了聊天室');
});

//收到別人發送的消息後,顯示消息
socket.on('broadcast_say', function(data) {

console.log(data.username + '說: ' + data.text);
});

//這里我們假設有一個文本框textarea和一個發送按鈕.btn-send
//使用jQuery綁定事件
$('.btn-send').click(function(e)
{
//獲取文本框的文本
var text = $('textarea').val();

//提交一個say事件,伺服器收到就會廣播
socket.emit('say', {
username: 'Username
hehe'
text: text
});
});

閱讀全文

與nodejs發送get請求相關的資料

熱點內容
iphone程序加密 瀏覽:884
win10文件夾調整文件行高 瀏覽:681
創意手繪教程 瀏覽:754
微信刪除帳號信息 瀏覽:596
mysql操作類文件 瀏覽:649
繞過xp密碼 瀏覽:158
大眾速騰專用app有哪些 瀏覽:455
arpa首先將計算機網路劃分為 瀏覽:617
蘋果系統開機音樂 瀏覽:875
windows8顯示隱藏文件 瀏覽:603
ipad2可以升級到92嗎 瀏覽:857
如何打開ps保存的文件 瀏覽:744
幼兒編程教育有哪些 瀏覽:453
汽車發外地用什麼app 瀏覽:810
網路如何贊美女人漂亮 瀏覽:143
如何把桌面文件放到excel裡面 瀏覽:363
照片文件名是怎麼查的 瀏覽:876
c怎麼在cmd模式下顯示文件 瀏覽:325
手機怎麼把文件夾的圖片移到相冊 瀏覽:440
hjc是啥文件的格式 瀏覽:298

友情鏈接