NodeJ node.js基礎

来源:https://www.cnblogs.com/reeber/archive/2019/04/11/HaisenBlog.html
-Advertisement-
Play Games

因為是Node伺服器端的,怎樣實現前臺和後臺請求以及回應 URL(由什麼組成的 ),傳輸的內容:表單數據 文件數據 【圖片、壓縮包、各種尾碼文件】 URL的組成 URL由三部分組成: 協議類型 , 主機名 和 路徑及文件名 。通過URL可以指定的主要有以下幾種:http、ftp、gopher、tel ...


 

因為是Node伺服器端的,怎樣實現前臺和後臺請求以及回應

URL(由什麼組成的 ),傳輸的內容:表單數據  文件數據 【圖片、壓縮包、各種尾碼文件】

URL的組成 URL由三部分組成: 協議類型 , 主機名 和 路徑及文件名 。通過URL可以指定的主要有以下幾種:http、ftp、gopher、telnet、file等。

--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------

前臺向後臺發送請求,後臺監聽收到獲取傳過來的 url以及path分析,對應請求的是什麼,我該怎麼回應

後臺讀寫文件操作

const fs=require('fs');
/**寫入文件操作 */
// fs.writeFile('./a.txt', 'asdfasdfad', err=>{
//   if(err){
//     console.log('失敗', err);
//   }else{
//     console.log('成功')
//   }
// });

/**讀取文件操作 */
fs.readFile('./a.txt', (err,data)=>{
  if(err){
    console.log('失敗')
  }else{
    console.log('成功' + data)
  }
});
View Code

創建http (這個是必須的  node一切通過你創建的http協議  屬於底層結構代碼)

const http = require('http');

let server = http.createServer(()=>{
    console.log('請求來了');
})
//伺服器一直在監聽 8080 埠 
server.listen(8080);
View Code

前臺html文件   後臺針對前臺某個路徑下的文件  接收請求

const http = require('http');
const fs = require('fs');


let server = http.createServer(function (req,res){
  console.log(req.url)
  fs.readFile(`www${req.url}`,(err,buffer)=>{
    if(err){
      res.writeHeader(404)
      console.log('error')
      res.end()
    }else{
      res.write(buffer)
      res.end();
    }
  })
});
server.listen(8080);
View Code

一旦接受請求http接受到請求就會 在req中就回有對應的屬性  獲取使用 例如 req.url  ,讀取到這個文件了  伺服器就會返回設置的響應

狀態碼:(百度百科)

https://baike.baidu.com/item/HTTP%E7%8A%B6%E6%80%81%E7%A0%81/5053660

大概分類 5類:

100 消息    200 請求成功   300重定向     400 請求錯誤(404)   500 就是伺服器錯誤

Form 前臺表單提交

<!DOCTYPE html>
<html lang="en" dir="ltr">
  <head>
    <meta charset="utf-8">
    <title></title>
  </head>
  <body>
    <form action="http://localhost:8080/reg" method="get">
      用戶:<input type="text" name="username" /><br>
      密碼:<input type="password" name="password" /><br>
      <input type="submit" value="提交" />
    </form>
  </body>
</html>
Get.html
const http = require('http');
const querystring = require('querystring');

let server = http.createServer(function(req,res){
    let [url,query] = req.url.split('?');
    console.log(url,query)
});

server.listen(8080);
Server_Get.js

 

Get_Url   導入一個 Url 就是專門做這個的

const http = require('http');
const url = require('url');

let server = http.createServer(function(req,res){
    // let result = url.parse(req.url,true);
    let {pathname,query} = url.parse(req.url,true);

    console.log(pathname,query)
});

server.listen(8080);
View Code

 

Post——獲取這個url中的信息呢 因為不可以使用 url 所以呢  相對複雜一點

const http = require('http');
const url = require('url');


let server = http.createServer(function(req,res){
    let arr = [];
    req.on('data',buffer=>{
        arr.push(buffer)
    })
    req.on('end',()=>{
        let result = Buffer.concat(arr)
        console.log(result.toString())
    })
    
})

server.listen(8080);
View Code

Post—— 引入queryString

const http = require('http');
const querystring = require('querystring');
const url = require('url');


let server = http.createServer(function(req,res){
    let arr = [];
    // req中的方法 
    req.on('data',buffer=>{
        arr.push(buffer)
    })
    req.on('end',()=>{
        // Buffer 中的會將數組中的值進行組合 
        let result = Buffer.concat(arr)
        // 通過querystring  將字元串 轉為 JSON格式的 
        let jsondata = querystring.parse(result.toString());
        // 列印輸出
        console.log(jsondata)
    })
    
})

server.listen(8080);
View Code

  •  引入node中的模塊包
    •   const http = require('http');
  • 字元串轉json
    • Url.parse(req.url,true) 
個人功能變數名稱:www.haisen.club

您的分享是我們最大的動力!

-Advertisement-
Play Games
更多相關文章
  • 這篇隨筆繼續來認識HTML標簽。這次隨筆主要是對<table>標簽的認識和最近我學習到的一些標簽來和大家分享。 一、<table>標簽 <table>標簽的作用主要是定義HTML表格,<table>內也分頭<thead>和主體<tbody>,而簡單的HTML表格由table元素以及一個或者多個tr, ...
  • import React, { Component } from 'react' import ReactDOM from 'react-dom' class App extends Component { constructor(props) { super(props); this.state ... ...
  • 示例代碼托管在: "http://www.github.com/dashnowords/blogs" 博客園地址: "《大史住在大前端》原創博文目錄" 華為雲社區地址: "【你要的前端打怪升級指南】" [TOC] 一. 任務說明 使用原生 繪製水球圖,這將是一個非常有意思的挑戰任務。水球圖是一種常見 ...
  • 本篇文檔主要是利用echarts實現可拖動節點的折現圖,在echarts中找到了一個demo,傳送門:https://echarts.baidu.com/examples/editor.html?c=line-draggable,但是不是用vue寫的,並且在改寫為vue組件的過程中遇到了很多問題,在 ...
  • 面試高頻之js的非同步載入 講這個問題之前, 我們從另一個面試高頻問題來切入, 我們的web頁面從開始解析到頁面渲染完成都經歷了什麼 ? 1 , 創建document對象, 開始解析頁面, 此時document.readyState = 'loading' 2 , 遇到link標簽引入的css文件, ...
  • 一. 框架 選用express框架 二. 簡單測試請求 在當前目錄新建index.js文件 複製代碼在終端輸入: node index.js 在瀏覽器中打開 127.0.0.1:3000 <! more 三.使用form上傳圖片 將index.js中的介面更新成 註意:index.js中的文件只要改 ...
  • 一、媒體(介)查詢 1.1 基本語法 媒體查詢由媒體類型和一個或多個檢測媒體特性的條件表達式組成。媒體查詢中可用於檢測的媒體特性有:width、height和color(等)。使用媒體查詢可以在不改變頁面內容的情況下,為特性的一些輸出設備定製顯示效果。 使用 @media 查詢,你可以針對不同的媒體 ...
  • CSS3的出現給網站頁面增加了活力,網站增色不少,有這麼小小的一款插件就能做出很多動畫效果。 最重要的是它:簡單易用、輕量級、無需 jQuery......他就是wow.js 地址:https://daneden.github.io/animate.css/ 也可以在這個地方看各種演示 下麵就讓我們 ...
一周排行
    -Advertisement-
    Play Games
  • 前言 本文介紹一款使用 C# 與 WPF 開發的音頻播放器,其界面簡潔大方,操作體驗流暢。該播放器支持多種音頻格式(如 MP4、WMA、OGG、FLAC 等),並具備標記、實時歌詞顯示等功能。 另外,還支持換膚及多語言(中英文)切換。核心音頻處理採用 FFmpeg 組件,獲得了廣泛認可,目前 Git ...
  • OAuth2.0授權驗證-gitee授權碼模式 本文主要介紹如何筆者自己是如何使用gitee提供的OAuth2.0協議完成授權驗證並登錄到自己的系統,完整模式如圖 1、創建應用 打開gitee個人中心->第三方應用->創建應用 創建應用後在我的應用界面,查看已創建應用的Client ID和Clien ...
  • 解決了這個問題:《winForm下,fastReport.net 從.net framework 升級到.net5遇到的錯誤“Operation is not supported on this platform.”》 本文內容轉載自:https://www.fcnsoft.com/Home/Sho ...
  • 國內文章 WPF 從裸 Win 32 的 WM_Pointer 消息獲取觸摸點繪製筆跡 https://www.cnblogs.com/lindexi/p/18390983 本文將告訴大家如何在 WPF 裡面,接收裸 Win 32 的 WM_Pointer 消息,從消息裡面獲取觸摸點信息,使用觸摸點 ...
  • 前言 給大家推薦一個專為新零售快消行業打造了一套高效的進銷存管理系統。 系統不僅具備強大的庫存管理功能,還集成了高性能的輕量級 POS 解決方案,確保頁面載入速度極快,提供良好的用戶體驗。 項目介紹 Dorisoy.POS 是一款基於 .NET 7 和 Angular 4 開發的新零售快消進銷存管理 ...
  • ABP CLI常用的代碼分享 一、確保環境配置正確 安裝.NET CLI: ABP CLI是基於.NET Core或.NET 5/6/7等更高版本構建的,因此首先需要在你的開發環境中安裝.NET CLI。這可以通過訪問Microsoft官網下載並安裝相應版本的.NET SDK來實現。 安裝ABP ...
  • 問題 問題是這樣的:第三方的webapi,需要先調用登陸介面獲取Cookie,訪問其它介面時攜帶Cookie信息。 但使用HttpClient類調用登陸介面,返回的Headers中沒有找到Cookie信息。 分析 首先,使用Postman測試該登陸介面,正常返回Cookie信息,說明是HttpCli ...
  • 國內文章 關於.NET在中國為什麼工資低的分析 https://www.cnblogs.com/thinkingmore/p/18406244 .NET在中國開發者的薪資偏低,主要因市場需求、技術棧選擇和企業文化等因素所致。歷史上,.NET曾因微軟的閉源策略發展受限,儘管後來推出了跨平臺的.NET ...
  • 在WPF開發應用中,動畫不僅可以引起用戶的註意與興趣,而且還使軟體更加便於使用。前面幾篇文章講解了畫筆(Brush),形狀(Shape),幾何圖形(Geometry),變換(Transform)等相關內容,今天繼續講解動畫相關內容和知識點,僅供學習分享使用,如有不足之處,還請指正。 ...
  • 什麼是委托? 委托可以說是把一個方法代入另一個方法執行,相當於指向函數的指針;事件就相當於保存委托的數組; 1.實例化委托的方式: 方式1:通過new創建實例: public delegate void ShowDelegate(); 或者 public delegate string ShowDe ...