[Node.js] Level 5. Express
Express Routes
Let's create an express route that accepts GET requests on'/tweets' and responds by sending back a static HTML file.
Create a GET route for '/tweets' and give it the proper callback. The callback function should accept two arguments: the request and the response.
Send back the file tweets.html, which lives under the project's root path. Remember to use __dirname to locate tweets.html.
Finally, have the express app listen on port 8080.
var express = require('express');
var app = express();
app.get('/tweets', function(request, response){
response.sendFile( __dirname + '/tweets.html');
}).listen(8080);
Route Params 250 PTS
Let's create a route that accepts dynamic arguments in the URL path and and responds with the quote from the proper author.
Start by creating a GET route for '/quotes' that takes a name parameter as part of the URL path.
Now, use the name parameter from the URL to retrieve a quote from the quotes object and write it out to the response. Note: No piping here, just write the quote string to the response like you did in previous levels (and then close the response).
var express = require('express');
var app = express();
var quotes = {
'einstein': 'Life is like riding a bicycle. To keep your balance you must keep moving',
'berners-lee': 'The Web does not just connect machines, it connects people',
'crockford': 'The good thing about reinventing the wheel is that you can get a round one',
'hofstadter': 'Which statement seems more true: (1) I have a brain. (2) I am a brain.'
};
app.get('/quotes/:name', function(req, response){
response.end(quotes[req.params.name]);
});
app.listen(8080);
Rendering
Instead of just writing out the quote to the response, let's try using an EJS template to render the response.
First, render the quote.ejs template to the response.
Next, make the name and the quote data available to the template.
res.locals = {name: req.params.name, quote: quote};
Inside quote.ejs, add the code needed to render the data you passed to the template.
<h2>Quote by <%= name %></h2> <blockquote>
<%= quote %>
</blockquote>
URL Building
Let's create a page which calls the Twitter search API and displays the last few results for Code School. The first step is to construct the proper URL, which is all you need to do in this challenge.
Complete the URL options which will be sent into the the urlmodule's format method. The URL you'll want to construct is the following: http://search.twitter.com/search.json?q=codeschool
Add the protocol attribute to options.
Add the host attribute to options.
Add the pathname attribute to options.
Add an attribute which takes an object of query parameters, in this case we only need q to search Twitter.
var url = require('url');
options = {
// add URL options here
protocol: 'http:',
host : 'search.twitter.com',
pathname : '/search.json',
query: {q:'codeschool'}
};
var searchURL = url.format(options);
console.log(searchURL);
Doing the Request
Next, we'll use the request module to make a simple web request and log the response to the console. You can use this example in the README.
To start, require the request module and assign the return function to a variable.
Next, issue a request to searchURL. Remember, the callback function for the request function takes three arguments: error, response and body.
Finally, log the response body to the console using console.log().
var url = require('url');
var options = {
protocol: "http:",
host: "search.twitter.com",
pathname: '/search.json',
query: { q: "codeschool"}
};
var searchURL = url.format(options);
var request = require('request');
request(searchURL, function(error, response , body){
console.log(body);
});
Express Server
Now, let's create an Express server which queries out for the search term and then returns the JSON.
Require the express module.
Create the Express server and name it app.
Create a route for GET requests to / (root path). Remember, the callback function takes two arguments: a request req and a response res.
In our new route, issue a request to searchURL and pipe the results into the response.
Finally, tell app to listen on port 8080.
var url = require('url');
var request = require('request');
var express = require('express');
var options = {
protocol: "http:",
host: "search.twitter.com",
pathname: '/search.json',
query: {
q: "codeschool"
}
};
var searchURL = url.format(options);
var app = express(); // Create server here
app.get('/', function(req, res){
request(searchURL).pipe(res);
}).listen(8080);
[Node.js] Level 5. Express的更多相关文章
- node.js 下依赖Express 实现post 4种方式提交参数
上面这个图好有意思啊,哈哈, v8威武啊.... 在2014年的最后一天和大家分享关于node.js 如何提交4种格式的post数据. 上上一篇说到了关于http协议里定义的4种常见数据的post方法 ...
- Node.js的框架-express
Node.js的框架 express 是第三方的 express const express=require('express'); const app=express(); const PORT=3 ...
- Node.js 实战 & 最佳 Express 项目架构
Node.js 实战 & 最佳 Express 项目架构 Express Koa refs https://github.com/xgqfrms/learn-node.js-by-practi ...
- node.js入门及express.js框架
node.js介绍 javascript原本只是用来处理前端,Node使得javascript编写服务端程序成为可能.于是前端开发者也可以借此轻松进入后端开发领域.Node是基于Google的V8引擎 ...
- node.js 基础学习 express安装使用
安装好nodeJs,我们需要使用命令行中安装express. 我这里默认将Node.js安装在C:\Program Files\nodCejs\盘中. 在保持联网的状态下,依次输入如下命令. npm ...
- 建立一个node.js服务器(使用express搭建第一个Web环境)
一.官网下载node.js 下载地址:https://nodejs.org/en/download/ 根据向导,下一步安装就可以了! 二.使用express搭建Web环境 express是一个开源的n ...
- Node.js 入门:Express + Mongoose 基础使用
前言 Express 是基于 Node.js 平台的 web 应用开发框架,在学习了 Node.js 的基础知识后,可以使用 Express 框架来搭建一个 web 应用,实现对数据库的增删查改. 数 ...
- Node.js原生及Express方法实现注册登录原理
由于本文只是实现其原理,所以没有使用数据库,只是在js里面模拟数据库,当然是种中还是需要用数据库的. 1.node.js原生方法 ①html页面,非常简单,没有一丝美化~我们叫它user.html & ...
- node.js上除了Express还有哪些好用的web开发框架
老司机都有体会, 开发本身没有多难, 最纠结其实是最初的技术和框架选型, 本没有绝对的好坏之分, 可一旦选择了不适合于自己业务场景的框架, 将来木已成舟后开发和维护成本都很高, 等发现不合适的时候更换 ...
随机推荐
- Building Robust and Flexible Event System in Unity3D
Building Robust and Flexible Event System in Unity3D 1. Prerequisites 1.1 Observer Pattern According ...
- Kylin的垃圾清理
在Kylin运行一段时间之后,有很多数据因为不再使用而变成了垃圾数据,这些数据占据着大量HDFS.HBASE等资源,当积累到一定规模时会对集群性能产生影响.这些垃圾数据主要包括: Purge之后原Cu ...
- Mac os 下的文件权限管理
Mac os 下的文件权限管理 命令 ls -l -A 结果 -rw-r--r-- 1 user admin 2326156 4 12 15:24 adb 横线代表空许可.r代表只读,w代表写,x代表 ...
- javascript中Date对象的应用
前面的话 简易日历作为javascript中Date对象的常见应用,用途较广泛.本文将详细说明简易日历的实现思路 效果演示 HTML说明 使用type=number的两个input分别作为年和月的输入 ...
- POJ3744 Scout YYF I 概率DP+矩阵快速幂
http://poj.org/problem?id=3744 题意:一条路,起点为1,有概率p走一步,概率1-p跳过一格(不走中间格的走两步),有n个点不能走,问到达终点(即最后一个坏点后)不踩坏点的 ...
- 冒泡排序 Exercise07_18
import java.util.Arrays; import java.util.Scanner; /** * @author 冰樱梦 * 时间:2018年12月 * 题目:冒泡排序 * */ pu ...
- HDU 1287 MC挖矿世界 set bfs
MC挖矿世界 题目连接: http://acm.uestc.edu.cn/#/problem/show/1287 Description 银牌爷和柱神开始玩MC啦,但是怪物实在是太多了,于是银牌爷决定 ...
- 稀疏编码直方图----一种超越HOG的轮廓特征
该论文是一篇来自CMU 的CVPR2013文章,提出了一种基于稀疏编码的轮廓特征,简称HSC(Histogram of Sparse Code),并在目标检测中全面超越了HOG(Histogram o ...
- Regulator IC forms convenient overvoltage detector
Figure 1 shows a simple, stand-alone overvoltage detector. The intent of the circuit is to monitor a ...
- CMSIS-SVD Reference
http://www.keil.com/pack/doc/cmsis/svd/html/modules.html SVD File Schema Levels Device Level Periphe ...