欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

如何利用Node.js與JSON搭建簡單的動態(tài)服務器

 更新時間:2020年06月16日 08:43:51   作者:努力了嗎梁同學  
這篇文章主要給大家介紹了關于如何利用Node.js與JSON搭建簡單的動態(tài)服務器的相關資料,文中通過示例代碼介紹的非常詳細,對大家學習或者使用Node.js具有一定的參考學習價值,需要的朋友們下面來一起學習學習吧

一、創(chuàng)建html頁面

創(chuàng)建4個頁面,index.html、register.html、sign_in.html、home.html

  • index.html 默認主頁
  • register.html 用于注冊賬號
  • sign_in.html 用于登錄賬號
  • home.html 用于顯示登錄后的頁面

主要代碼片段

register.html

<form id="registerForm">
 <div>
  <label for="">用戶名:<input type="text" name="name" id=""></label>
 </div>
 <div>
  <label for="">密碼:<input type="password" name="password" id=""></label>
 </div>
 <div>
  <button type="submit">注冊</button>
 </div>
</form>
<script src="https://cdn.bootcdn.net/ajax/libs/jquery/3.5.1/jquery.min.js"></script>
<script>
let $form = $('#registerForm')
$form.on('submit', (e) => {
 e.preventDefault()
 const name = $form.find("input[name=name]").val()
 const password = $form.find('input[name=password').val()
 console.log(name, password)
 // pass AJAX post data
 $.ajax({
  method: 'post',
  url: '/register',
  contentType: 'text/json; charset=UTF-8',
  data: JSON.stringify({
   name, // name: name 
   password // password: password
  })
 }).then(() => {
  alert('注冊成功')
  location.href = '/sign_in.html'
 }, () => {})
})
</script>

sign_in.html

<form id="signInForm">
 <div>
  <label for="">用戶名:<input type="text" name="name" id=""></label>
 </div>
 <div>
  <label for="">密碼:<input type="password" name="password" id=""></label>
 </div>
 <div>
  <button type="submit">登錄</button>
 </div>
</form>
<script src="https://cdn.bootcdn.net/ajax/libs/jquery/3.5.1/jquery.min.js"></script>
<script>
 let $form = $('#signInForm')
 $form.on('submit', (e) => {
  e.preventDefault()
  // get name password
  const name = $form.find("input[name=name]").val()
  const password = $form.find('input[name=password').val()
  // pass AJAX post data
  $.ajax({
   method: 'POST',
   url: '/sign_in',
   contentType: 'text/json; charset=UTF-8',
   data: JSON.stringify({
    name,
    password
   })
  }).then(() => {
   alert('登錄成功')
   location.href = '/home.html'
  }, () => {})
 })
</script>

home.html

<p>
 {{loginStatus}}
</p>
<p>
 你好,{{user.name}}
</p>
<p>
 <a href="sign_in.html">登錄</a>
</p>

二、Node服務器

var http = require('http')
var fs = require('fs')
var url = require('url')
var port = process.argv[2]

if (!port) {
 console.log('請輸入指定端口。如:\nnode server.js 8888')
 process.exit(1)
}

var server = http.createServer(function (request, response) {
 var parsedUrl = url.parse(request.url, true)
 var pathWithQuery = request.url
 var queryString = ''
 if (pathWithQuery.indexOf('?') >= 0) {
  queryString = pathWithQuery.substring(pathWithQuery.indexOf('?'))
 }
 var path = parsedUrl.pathname
 var query = parsedUrl.query
 var method = request.method

 /******** main start ************/
 // 讀取 session 文件,轉化為對象
 const session = JSON.parse(fs.readFileSync('./session.json').toString())

 if (path === '/sign_in' && method === 'POST') {
  // 讀數據庫
  let userArray = JSON.parse(fs.readFileSync('./database/users.json'))
  const array = []
  // 每次接受數據就添加進數組
  request.on('data', (chunk) => {
   array.push(chunk)
  })
  request.on('end', () => {
   // 轉化字符串
   const string = Buffer.concat(array).toString()
   // 在轉化為對象
   const obj = JSON.parse(string)
   // 找到符合的 user
   const user = userArray.find(user => user.name === obj.name && user.password === obj.password) // 成功返回符合的對象,失敗返回undefined
   if (user === undefined) { // 失敗
    response.statusCode = 400
    response.setHeader('content-Type', 'text/JSON; charset=UTF-8')
    response.end(`{"errorCode":4001}`)
   } else { // 成功
    response.statusCode = 200
    // 設置 Cookie
    const random = Math.random()
    session[random] = {
     user_id: user.id
    }
    // 寫入數據
    fs.writeFileSync('./session.json', JSON.stringify(session))
    response.setHeader("Set-Cookie", `'session_id=${random}; HttpOnly'`)
    response.end()
   }
  })
 } else if (path === '/home.html') {
  // 獲取 Cookie
  const cookie = request.headers['cookie']
  let sessionId
  try { // 讀取 Cookie 中的 id 值
   sessionId = cookie.split(';').filter(s => s.indexOf('session_id=') >= 0)[0].split('=')[1]
  } catch (error) {}
  if (sessionId && session[sessionId]) {
   // 從 session 中讀取對應的值
   const userId = session[sessionId].user_id
   // 讀數據庫
   let userArray = JSON.parse(fs.readFileSync('./database/users.json'))
   // 找到符合的 user
   let user = userArray.find(user => user.id === userId)
   const homeHtml = fs.readFileSync('./public/home.html').toString()
   let string
   if (user) {
    string = homeHtml.replace('{{loginStatus}}', '已登錄').replace('{{user.name}}', user.name)
    response.write(string)
   }
  } else {
   // 讀取源文件內容
   const homeHtml = fs.readFileSync('./public/home.html').toString()
   // 替換文字
   const string = homeHtml.replace('{{loginStatus}}', '未登錄').replace('{{user.name}}', '')
   response.write(string)
  }
  response.end()
 } else if (path === '/register' && method === 'POST') {
  response.setHeader('Content-Type', 'text/html; charset=UTF-8')
  // read database
  let userArray = JSON.parse(fs.readFileSync('./database/users.json')) // read database
  const array = []
  request.on('data', (chunk) => {
   array.push(chunk)
  })
  request.on('end', () => {
   // convert string
   const string = Buffer.concat(array).toString()
   // convert obj
   const obj = JSON.parse(string)
   // last user id
   const lastUser = userArray[userArray.length - 1]
   // new user
   const newUser = {
    id: lastUser ? lastUser.id + 1 : 1,
    name: obj.name,
    password: obj.password
   }
   userArray.push(newUser)
   // write data
   fs.writeFileSync('./database/users.json', JSON.stringify(userArray))
  })
  response.end()
 } else {
  response.statusCode = 200
  let content
  // setting index
  const filePath = path === '/' ? '/index.html' : path
  // judge type
  const index = filePath.lastIndexOf('.')
  const suffix = filePath.substring(index)
  const fileType = {
   '.html': 'text/html',
   '.css': 'text/css',
   '.js': 'text/javascript'
  }
  response.setHeader('Content-Type', `${fileType[suffix] || "text/html"};charset=utf-8`)
  try {
   content = fs.readFileSync(`./public${filePath}`)
  } catch (error) {
   content = '文件路徑不存在'
   response.statusCode = 404
  }
  response.write(content)
  response.end()
 }

 /******** main end ************/
})

server.listen(port)
console.log('監(jiān)聽 ' + port + ' 成功!請輸入下列地址訪問\nhttp://localhost:' + port)

三、主要思路

register.html

使用jQuery的ajax將數據發(fā)送請求 /register 給后端,成功則跳轉到 sign_in.html

數據需要使用 JSON.stringify 轉化為字符串在提交

/register

讀取 users.json 的數據,創(chuàng)建一個空數組,將傳遞過來的參數 push 進去。將數組轉換為字符串,在轉換為對象。
獲取數據庫中最小的 id 值,將數據組成新的對象,添加進入 數據庫 中。

sign_in.html

使用ajax將數據發(fā)送請求 /sign_in 給后端,成功則跳轉 home.html

/sign_in

讀取 users.json 的數據,創(chuàng)建一個空數組,將傳遞過來的參數 push 進去。將數組轉換為字符串,在轉換為對象。
在讀取后的數據庫中,查找有沒有符合條件的 user,成功返回讀取后的對象,失敗返回 undefined。
如果成功,設置隨機數,將 隨機數的值 與 user的id 綁定。并添加到 session.json 中。然后 setHeader,將cookie發(fā)送到瀏覽器。

/home

獲取登入成功后 cookie 的值。讀取 session 中對應的隨機數。如果隨機數和session對應的隨機數值存在,就顯示已登錄,否則顯示未登錄

總結

到此這篇關于如何利用Node.js與JSON搭建簡單的動態(tài)服務器的文章就介紹到這了,更多相關Node.js與JSON搭建動態(tài)服務器內容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關文章希望大家以后多多支持腳本之家!

相關文章

  • 一文學會搭建HTTP服務器調用DLL庫

    一文學會搭建HTTP服務器調用DLL庫

    這篇文章主要為大家介紹了一文學會搭建HTTP服務器調用DLL庫,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進步,早日升職加薪
    2023-06-06
  • 淺析 NodeJs 的幾種文件路徑

    淺析 NodeJs 的幾種文件路徑

    本篇文章主要介紹了淺析 NodeJs 的幾種文件路徑,小編覺得挺不錯的,現在分享給大家,也給大家做個參考。一起跟隨小編過來看看吧
    2017-06-06
  • 基于Node.js搭建hexo博客過程詳解

    基于Node.js搭建hexo博客過程詳解

    這篇文章主要介紹了基于Node.js搭建hexo博客過程詳解,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,
    2019-06-06
  • node微信小程序登錄實現登錄的項目實踐

    node微信小程序登錄實現登錄的項目實踐

    登陸流程是指小程序用戶進行授權登陸,即獲取用戶的微信賬號等信息本文就來介紹一下node微信小程序登錄實現登錄,具有一定的參考價值,感興趣的可以了解一下
    2023-09-09
  • 詳解Node.Js如何處理post數據

    詳解Node.Js如何處理post數據

    這篇文章給大家介紹了如何利用Node.Js處理post數據,文中通過實例和圖文介紹的很詳細,有需要的小伙伴們可以參考借鑒,下面來一起看看吧。
    2016-09-09
  • 淺談Node.js 中間件模式

    淺談Node.js 中間件模式

    中間件在 Node.js 中被廣泛使用,它泛指一種特定的設計模式、一系列的處理單元、過濾器和處理程序,以函數的形式存在,這篇文章主要介紹了淺談Node.js 中間件模式,小編覺得挺不錯的,現在分享給大家,也給大家做個參考。一起跟隨小編過來看看吧
    2018-06-06
  • Nodejs實現短信驗證碼功能

    Nodejs實現短信驗證碼功能

    使用Nodejs的開發(fā)者愈來越多,基于Nodejs的后臺開發(fā)也多了起來,像短信驗證碼、短信群發(fā)、國際短信這些需求,完全可以采用第三方接口來實現,云片就提供了這樣的接口
    2017-02-02
  • Node如何實現在瀏覽器預覽項目的所有圖片詳解

    Node如何實現在瀏覽器預覽項目的所有圖片詳解

    最近項目遇到了個需求,需要將存放圖片進行預覽,所以這篇文章主要給大家介紹了關于Node如何實現在瀏覽器預覽項目的所有圖片的相關資料,文中通過實例代碼介紹的非常詳細,需要的朋友可以參考下
    2023-01-01
  • 阿里大于短信驗證碼node koa2的實現代碼(最新)

    阿里大于短信驗證碼node koa2的實現代碼(最新)

    本文給大家分享一個最新版阿里大于短信驗證碼node koa2的實現代碼及注意事項,需要的朋友參考下吧
    2017-09-09
  • Nest.js中使用HTTP五種數據傳輸方式小結

    Nest.js中使用HTTP五種數據傳輸方式小結

    本文主要介紹了Nest.js中使用HTTP五種數據傳輸方式小結,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧
    2023-05-05

最新評論