이 글은 node.js에서 라우팅, 미들웨어, ge 요청 및 포스트 요청 매개변수를 사용하는 방법을 요약한 것입니다. 도움이 필요한 친구들은 이를 참고할 수 있습니다.
1 Routing
1. 라우팅 중입니다
서버는 다양한 URL이나 요청에 따라 다양한 작업을 수행해야 합니다. 라우팅을 통해 이 단계를 구현할 수 있습니다
2. 라우팅 구현 방법
2.1 URL에 대한 액세스를 요청할 때 무엇을 합니까?
2.2. 게시물이 URLapp.get("网址",function(req,res){ });
app.post("网址",function(req,res){ });
app.all("网址",function(){ });
app.get("/AAb",function(req,res){ //我们访问 /aab也是可以的 res.send("你好"); });
app.get(/^\/student\/([\d]{10})$/,function(req,res){ res.send("学生信息,学号" + req.params[0]); });
미들웨어란 무엇입니까
다음과 같은 용도로 사용됩니다. 예를 들어 위의 get 및 post 요청은 middleware 2입니다. express의 모든 경로(미들웨어) 순서(매우 중요) 2.1.next() 메서드var express=require('express'); var app=express(); //冒号1 app.get("/student/:id",function (req,res) { var id=req.params["id"]; //得到id的值 var reg=/^[\d]{6}$/; if(reg.test(id)){ res.send(id); }else { res.send("请检查格式"); } }); //冒号2 app.get("/:username/:oid",function(req,res){ var username = req.params["username"]; //得到username的值 var oid = req.params["oid"]; //得到//oid的值 res.write(username); res.end(oid); }); app.listen(3000);
var express=require("express"); var app=express(); app.get("/",function (req,res,next) { console.log(1); next(); //如果没有next参数,就只会conlose出来1,而不会是1,2 }); app.get("/",function (req,res) { console.log(2); }); app.listen(3000);
var express=require("express"); var app=express(); app.get("/:username/:id",function(req,res){ console.log("1"); res.send("用户信息" + req.params.username); }); app.get("/admin/login",function(req,res){ console.log("2"); res.send("管理员登录"); }); app.listen(3000)
var express=require("express"); var app=express(); //具体的 app.get("/admin/login",function(req,res){ console.log("2"); res.send("管理员登录"); }); //抽象的 app.get("/:username/:id",function(req,res){ console.log("1"); res.send("用户信息" + req.params.username); }); app.listen(3000)
var express=require("express"); var app=express(); app.get("/:username/:id",function (req,res,next) { var username=req.params.username; //检索数据库,如果username 不存在,那么next() if(检索数据库){ console.log("1"); res.send("用户信息") }else{ next(); } }); app.get("/admin/login",function (req,res) { console.log("2"); res.send("管理员登录"); }); app.listen(3000)
var express=require("express"); var app=express(); //匹配所有网址 //法一 //当你不写路径的时候,实际上就相当于“/”,就是所有网址 // app.use(function (req,res,next) { // console.log(new Date()); // next(); //执行下面的 // }); //法二 app.use("/",function (req,res,next) { console.log(new Date()); next(); //执行下面的 }); //匹配/admin所有地址,例如/admin/ss/aa这个都行 app.use("/admin",function (req,res) { res.write(req.originalUrl+"\n"); // /admin/ss/aa res.write(req.path+"\n"); // /ss/aa res.write(req.baseUrl+"\n"); // /admin res.end("你好"); }); app.listen(3000);
4.2, res.render()는 뷰의 템플릿 파일에 따라 콘텐츠를 렌더링합니다. views 폴더를 사용하지 않고 폴더명을 직접 설정하고 싶다면 app.set("views","aaaa");
var express=require("express"); var fs=require("fs"); var app=express(); //当你不写路径的时候,实际上就相当于“/”,就是所有网址 app.use(haha); //haha是一个函数 app.listen(3000); // function haha(req,res) { // res.send("哈哈"); // } app.use('/admin',function (req,res) { res.send('管理员登录'); }) //根据当前的网址,读取punlic文件夹的文件 //如果有这个文件,就渲染这个文件 //如果没有这个文件,那么next() function haha(req,res,next) { var filePath=req.originalUrl; //根据当前的网址,读取public文件夹的文件 //如果有这个文件,那么渲染这个文件 //如果没哟偶这个文件,那么next(); fs.readFile("./public/"+filePath,function (err,data) { if(err){ //文件不存在 next(); //一定要写,不然处于挂起状态 return; } res.send(data.toString()); }) }
5. req.query : http://127.0 입력 시 .0.1:3000/? id=0&ag=9
var express=require("express"); var app=express(); //静态服务 app.use('/jingtai',express.static("./public")); //新的路由 app.get('/images',function (req,res) { res.send("哈哈") }); //会自动识别err参数,如果有,那么就这个函数能捕获err app.use(function (req,res) { res.status(404).send("没有这个页面!"); }) app.listen(3000);
작업 결과:
3. 요청 매개변수 게시 요청 매개변수 가져오기:
요청 매개변수 가져오기: URL에서 Express에서는 필요하지 않습니다. url 모듈을 사용합니다. req.query 객체를 직접 사용할 수 있습니다. POST 요청 매개변수: Express에서 직접 얻을 수 없으며 body-parser 모듈을 사용해야 합니다. 사용 후 req.body를 사용하여 매개변수를 가져올 수 있습니다. 그러나 양식에 파일 업로드가 포함되어 있으면 여전히 강력한 모듈을 사용해야 합니다.
var express=require("express"); var app=express(); // //设置ejs文件夹名字 //在day3文件夹下新建文件夹a,然后在里面放ejs文件 // app.set("views","a") app.set("view engine","ejs"); app.get("/",function(req,res) { res.render("haha",{news:[]}); }); app.get("/check",function (req,res) { res.send({ "user":"ok" }) }) app.listen(3000);
var express=require("express"); var app=express(); app.get("/",function (req,res) { console.log(req.query); res.send(); }); app.listen(3000);
실행 결과:
위 내용은 제가 모든 사람을 위해 정리한 내용입니다. 앞으로 모든 사람에게 도움이 되기를 바랍니다.관련 기사:
Vue에서 ajax를 사용하는 방법은 무엇인가요?Angular2를 사용하여 플러그인을 통합하는 방법(자세한 튜토리얼)
Javascript 배열을 평면화하는 방법은 무엇입니까?
위 내용은 node.js의 라우팅 및 미들웨어에 대한 자세한 소개의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!