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
  • 移動開發(一):使用.NET MAUI開發第一個安卓APP 對於工作多年的C#程式員來說,近來想嘗試開發一款安卓APP,考慮了很久最終選擇使用.NET MAUI這個微軟官方的框架來嘗試體驗開發安卓APP,畢竟是使用Visual Studio開發工具,使用起來也比較的順手,結合微軟官方的教程進行了安卓 ...
  • 前言 QuestPDF 是一個開源 .NET 庫,用於生成 PDF 文檔。使用了C# Fluent API方式可簡化開發、減少錯誤並提高工作效率。利用它可以輕鬆生成 PDF 報告、發票、導出文件等。 項目介紹 QuestPDF 是一個革命性的開源 .NET 庫,它徹底改變了我們生成 PDF 文檔的方 ...
  • 項目地址 項目後端地址: https://github.com/ZyPLJ/ZYTteeHole 項目前端頁面地址: ZyPLJ/TreeHoleVue (github.com) https://github.com/ZyPLJ/TreeHoleVue 目前項目測試訪問地址: http://tree ...
  • 話不多說,直接開乾 一.下載 1.官方鏈接下載: https://www.microsoft.com/zh-cn/sql-server/sql-server-downloads 2.在下載目錄中找到下麵這個小的安裝包 SQL2022-SSEI-Dev.exe,運行開始下載SQL server; 二. ...
  • 前言 隨著物聯網(IoT)技術的迅猛發展,MQTT(消息隊列遙測傳輸)協議憑藉其輕量級和高效性,已成為眾多物聯網應用的首選通信標準。 MQTTnet 作為一個高性能的 .NET 開源庫,為 .NET 平臺上的 MQTT 客戶端與伺服器開發提供了強大的支持。 本文將全面介紹 MQTTnet 的核心功能 ...
  • Serilog支持多種接收器用於日誌存儲,增強器用於添加屬性,LogContext管理動態屬性,支持多種輸出格式包括純文本、JSON及ExpressionTemplate。還提供了自定義格式化選項,適用於不同需求。 ...
  • 目錄簡介獲取 HTML 文檔解析 HTML 文檔測試參考文章 簡介 動態內容網站使用 JavaScript 腳本動態檢索和渲染數據,爬取信息時需要模擬瀏覽器行為,否則獲取到的源碼基本是空的。 本文使用的爬取步驟如下: 使用 Selenium 獲取渲染後的 HTML 文檔 使用 HtmlAgility ...
  • 1.前言 什麼是熱更新 游戲或者軟體更新時,無需重新下載客戶端進行安裝,而是在應用程式啟動的情況下,在內部進行資源或者代碼更新 Unity目前常用熱更新解決方案 HybridCLR,Xlua,ILRuntime等 Unity目前常用資源管理解決方案 AssetBundles,Addressable, ...
  • 本文章主要是在C# ASP.NET Core Web API框架實現向手機發送驗證碼簡訊功能。這裡我選擇是一個互億無線簡訊驗證碼平臺,其實像阿裡雲,騰訊雲上面也可以。 首先我們先去 互億無線 https://www.ihuyi.com/api/sms.html 去註冊一個賬號 註冊完成賬號後,它會送 ...
  • 通過以下方式可以高效,並保證數據同步的可靠性 1.API設計 使用RESTful設計,確保API端點明確,並使用適當的HTTP方法(如POST用於創建,PUT用於更新)。 設計清晰的請求和響應模型,以確保客戶端能夠理解預期格式。 2.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...