在看react-native教程的時候,遇到要在手機端調試,需要api服務器,但是由于Node.js自己就作為服務器,沒有apache怎么解決這個問題,用apache和nginx也可以解決,但是有點復雜,我們就使用node已有的模塊解決這個問題.
//服務器端的代碼var express = require('express');var app = express();// set up handlebars view enginevar handlebars = require('express3-handlebars') .create({ defaultLayout:'main' });app.engine('handlebars', handlebars.engine);app.set('view engine', 'handlebars');app.set('port', process.env.PORT || 3000);app.use(express.static(__dirname + '/public'));var fortuneCookies = [ "Conquer your fears or they will conquer you.", "Rivers need springs.", "Do not fear what you don't know.", "You will have a pleasant surprise.", "Whenever possible, keep it simple.",];app.get('/', function(req, res) { res.render('home');});app.get('/about', function(req,res){ var randomFortune = fortuneCookies[Math.floor(Math.random() * fortuneCookies.length)]; res.render('about', { fortune: randomFortune });});// 404 catch-all handler (middleware)app.use(function(req, res, next){ res.status(404); res.render('404');});// 500 error handler (middleware)app.use(function(err, req, res, next){ console.error(err.stack); res.status(500); res.render('500');});app.listen(app.get('port'), function(){ console.log( 'Express started on http://localhost:' + app.get('port') + '; press Ctrl-C to terminate.' );});上面這段代碼在127.0.0.1:3000端口啟動一個本地服務器,但是在手機端是不能訪問的.
我們再啟動另一個node.js服務器來解決這個問題.
//proxy.js var http = require('http'), httpProxy = require('http-proxy'); //引入這個模塊// 新建一個代理 Proxy Server 對象 var proxy = httpProxy.createProxyServer({}); // 捕獲異常 proxy.on('error', function (err, req, res) { res.writeHead(500, { 'Content-Type': 'text/plain' }); res.end('Something went wrong. And we are reporting a custom error message.'); }); // 另外新建一個 HTTP 80 端口的服務器,也就是常規 Node 創建 HTTP 服務器的方法。 // 在每次請求中,調用 proxy.web(req, res config) 方法進行請求分發 var server = require('http').createServer(function(req, res) { // 在這里可以自定義你的路由分發 var host = req.headers.host, ip = req.headers['x-forwarded-for'] || req.connection.remoteAddress; console.log("client ip:" + ip + ", host:" + host); switch(host){ //意思是監聽下面的ip地址,如果匹配就轉到//127.0.0.1:3000地址 case '192.168.0.101:8080': //監聽這個地址 //這個地址在window上用ipconfig查看,mac/linux用ifconfig查看 case 'bbs.aaaa.com': proxy.web(req, res, { target: 'http://127.0.0.1:3000' }); //轉到這個地址 break; default: res.writeHead(200, { 'Content-Type': 'text/plain' }); res.end('Welcome to my server!'); } }); console.log("listening on port 8080") server.listen(8080);
新聞熱點
疑難解答
圖片精選