当前位置: 首页 > news >正文

js创建服务器,以及对接口的理解和创建

// 创建服务
const app = http.createServer((req, res)=>{
    // 设置给前端返回信息的字符编码

    res.setHeader('content-type', 'text/html; charset=utf-8')    
    let address = req.url.split('?')[0]
    //首先创建一个数组,后面把它的数据放在JSON文件
    let user = [{id: 1, username: 'user1', password: '123'}]
    //拿到query,它是一个对象,里面有ID,usermane,password
    let objParams = url.parse(req.url, true).query
console.log(url.parse(req.url, true))
    // 使用switch进行匹配
    switch(address){
        // 页面的静态托管
        case '/index.html':
            fs.readFile('./index.html', 'utf-8', (err, data)=>{
                res.end(data)
            })
            break
        case '/login.html':
            fs.readFile('./login.html', 'utf-8', (err, data)=>{
                res.end(data)
             })   
             break
       
        case '/user/login':
            // res.end(JSON.stringify({code: 1, message: '登录成功'}))
            // 把传递过来的参数和db数据库里面的参数进行对比
            fs.readFile('./db/register.json', 'utf-8', (err, data)=>{
                let {username, password} = objParams
               //  console.log(username, password)
                let result = JSON.parse(data).find(item=>{
                    return item.username === username && item.password === password 
                })
                if(!result){
                    // 注意点:如果验证不通过,必须返回的是用户名或者密码错误,这样可以增加安全性
                    res.end(JSON.stringify({code: 0, message: '用户名或者密码错误'}))
                }else{
                    res.end(JSON.stringify({code: 1, message: '登录成功'}))
                    
                }
            })   
            break
        case '/shopping/list':
            fs.readFile('./db/goods.json', 'utf-8', (err, data)=>{
                res.end(data)
            })   
        case '/user/register':
            // fs.writeFile('./db/register.json', JSON.stringify(user), ()=>{
            //     res.end(JSON.stringify({code: 1, message: '注册成功'}))
            // })
            // 先读,再写
            fs.readFile('./db/register.json', 'utf-8', (err,data)=>{
                user.push(objParams)
        console.log(data)
                fs.writeFile('./db/register.json', JSON.stringify(user), ()=>{
            
                    res.end(JSON.stringify({code: 1, message: '注册成功'}))
                    
                })
            })
            break
        default:
            res.end('<h1>404,你的页面走丢了!</h1>') 
    }

})

// 监听端口号
app.listen(2307, ()=>{
    console.log('你的服务器已经开启了,快来玩啊!http://localhost:2307')
})

http://www.lryc.cn/news/272462.html

相关文章:

  • 【Bootstrap学习 day7】
  • Zookeeper无法启动,报“Unable to load database on disk”
  • 【Web2D/3D】CSS3的2D/3D转换、过渡、动画(第一篇)
  • uView NumberBox 步进器
  • 三菱plc的点动控制循环(小灯闪烁,单控气缸循环)
  • 学习Go语言Web框架Gee总结--http.Handler(一)
  • react+redux+antd-mobile 之 记账本案例
  • Day22
  • Windows下linux 子系统 WSL2怎样使用usb串口(USBIPD-win4.0.0)
  • 飞腾Ubantu22.04.3安装OpenNebula测试
  • gookit/color - Go语言命令行色彩使用库教程
  • python弹奏《起风了》
  • Linux---all
  • 前端中级算法题
  • Ant Design Vue 编译后的网页特点是什么,怎么确认他是用的前端 Ant Design Vue 技术栈的呢?
  • python | PYTHON正则表达式
  • 为什么大学c语言课不顺便教一下Linux,Makefile
  • Go后端开发 -- main函数 变量 常量 函数
  • 2023/12/30 c++ work
  • ctfshow——文件上传
  • 【RocketMQ每日一问】RocketMQ SQL92过滤用法以及原理?
  • Go语言中的包管理工具之Go Path的使用
  • cocos creator(2.4.7版本) webview 可以在上层添加UI控件
  • 2023 年四川省职业院校技能大赛“信息安全管理与评估”样题
  • ubuntu2204,mysql8.x安装
  • CG Magic分享云渲染和本地渲染之间的区别有什么?
  • 【算法与数据结构】763、LeetCode划分字母区间
  • 新火种AI|人形机器人敲响上市罗,首日市值高达390亿港元
  • SpringMVC框架
  • FreeRTOS——计数型信号量知识总结及实战