REST API 开发
本文我们将使用Spring MVC 4实现 CRUD Restful WebService , 通过RestTemplate写一个 REST 客户端,定义这些服务. 我们也可以通过外部的一些客户端来测试这些服务。
简短 & 快速介绍REST
REST表示 Representational State Transfer(表示性状态转换).
它是可以用来设计web services的框架,可以被不同的客户端调用。
核心思想是:使用简单的HTTP协议来实现调用,而不是CORBA, RPC 或者 SOAP等负责的机制。
在Rest 基础设计中,资源使用以下动词进行操作。
- 创建资源 : 使用 HTTP POST
- 获取资源 : 使用 HTTP GET
- 更新资源 : 使用 HTTP PUT
- 删除资源 : 使用 HTTP DELETE
也意味着,你作为Rest 服务开发者或者客户,应该遵循以上的标准。
尽管没有限制必须返回的类型,但是一般基于Web services的Rest返回JSON或者XML作为响应。
客户端可以指定(使用HTTP Accept header)他们想要的资源类型吗,服务器返回需要的资源。
指明资源的Content-Type。如果想详细的理解 restful可以参考这里:StackOverflow link
基于Rest的Controller(控制器)
我们的 REST API :
- GET 方式请求 /api/user/ 返回用户列表
- GET 方式请求 /api/user/1返回id为1的用户
- POST 方式请求 /api/user/ 通过user对象的JSON 参数创建新的user对象
- PUT 方式请求 /api/user/3 更新id为3的发送json格式的用户对象
- DELETE 方式请求/api/user/4删除 ID为 4的user对象
- DELETE 方式请求/api/user/删除所有user
- package com.websystique.springmvc.controller;
- import java.util.List;
- import org.springframework.beans.factory.annotation.Autowired;
- import org.springframework.http.HttpHeaders;
- import org.springframework.http.HttpStatus;
- import org.springframework.http.MediaType;
- import org.springframework.http.ResponseEntity;
- import org.springframework.web.bind.annotation.PathVariable;
- import org.springframework.web.bind.annotation.RequestBody;
- import org.springframework.web.bind.annotation.RequestMapping;
- import org.springframework.web.bind.annotation.RequestMethod;
- import org.springframework.web.bind.annotation.RestController;
- import org.springframework.web.util.UriComponentsBuilder;
- import com.websystique.springmvc.model.User;
- import com.websystique.springmvc.service.UserService;
- @RestController
- public class HelloWorldRestController {
- @Autowired
- UserService userService; //Service which will do all data retrieval/manipulation work
- //-------------------Retrieve All Users--------------------------------------------------------
- @RequestMapping(value = "/user/", method = RequestMethod.GET)
- public ResponseEntity<List<User>> listAllUsers() {
- List<User> users = userService.findAllUsers();
- if(users.isEmpty()){
- return new ResponseEntity<List<User>>(HttpStatus.NO_CONTENT);//You many decide to return HttpStatus.NOT_FOUND
- }
- return new ResponseEntity<List<User>>(users, HttpStatus.OK);
- }
- //-------------------Retrieve Single User--------------------------------------------------------
- @RequestMapping(value = "/user/{id}", method = RequestMethod.GET, produces = MediaType.APPLICATION_JSON_VALUE)
- public ResponseEntity<User> getUser(@PathVariable("id") long id) {
- System.out.println("Fetching User with id " + id);
- User user = userService.findById(id);
- if (user == null) {
- System.out.println("User with id " + id + " not found");
- return new ResponseEntity<User>(HttpStatus.NOT_FOUND);
- }
- return new ResponseEntity<User>(user, HttpStatus.OK);
- }
- //-------------------Create a User--------------------------------------------------------
- @RequestMapping(value = "/user/", method = RequestMethod.POST)
- public ResponseEntity<Void> createUser(@RequestBody User user, UriComponentsBuilder ucBuilder) {
- System.out.println("Creating User " + user.getName());
- if (userService.isUserExist(user)) {
- System.out.println("A User with name " + user.getName() + " already exist");
- return new ResponseEntity<Void>(HttpStatus.CONFLICT);
- }
- userService.saveUser(user);
- HttpHeaders headers = new HttpHeaders();
- headers.setLocation(ucBuilder.path("/user/{id}").buildAndExpand(user.getId()).toUri());
- return new ResponseEntity<Void>(headers, HttpStatus.CREATED);
- }
- //------------------- Update a User --------------------------------------------------------
- @RequestMapping(value = "/user/{id}", method = RequestMethod.PUT)
- public ResponseEntity<User> updateUser(@PathVariable("id") long id, @RequestBody User user) {
- System.out.println("Updating User " + id);
- User currentUser = userService.findById(id);
- if (currentUser==null) {
- System.out.println("User with id " + id + " not found");
- return new ResponseEntity<User>(HttpStatus.NOT_FOUND);
- }
- currentUser.setName(user.getName());
- currentUser.setAge(user.getAge());
- currentUser.setSalary(user.getSalary());
- userService.updateUser(currentUser);
- return new ResponseEntity<User>(currentUser, HttpStatus.OK);
- }
- //------------------- Delete a User --------------------------------------------------------
- @RequestMapping(value = "/user/{id}", method = RequestMethod.DELETE)
- public ResponseEntity<User> deleteUser(@PathVariable("id") long id) {
- System.out.println("Fetching & Deleting User with id " + id);
- User user = userService.findById(id);
- if (user == null) {
- System.out.println("Unable to delete. User with id " + id + " not found");
- return new ResponseEntity<User>(HttpStatus.NOT_FOUND);
- }
- userService.deleteUserById(id);
- return new ResponseEntity<User>(HttpStatus.NO_CONTENT);
- }
- //------------------- Delete All Users --------------------------------------------------------
- @RequestMapping(value = "/user/", method = RequestMethod.DELETE)
- public ResponseEntity<User> deleteAllUsers() {
- System.out.println("Deleting All Users");
- userService.deleteAllUsers();
- return new ResponseEntity<User>(HttpStatus.NO_CONTENT);
- }
- }
详解:
@RestController :首先我们使用的是Spring 4的新注解 @RestController注解.
此注解避免了每个方法都要加上@ResponseBody注解。也就是说@RestController 自己戴上了 @ResponseBody注解,看以看作是
@Controller 和 @ResponseBody的结合体。
@RequestBody : 如果方法参数被 @RequestBody注解,Spring将绑定HTTP请求体到那个参数上。如果那样做,Spring将根据请求中的ACCEPT或者 Content-Type header(私下)使用 HTTP Message converters 来将http请求体转化为domain对象。
@ResponseBody : 如果方法加上了@ResponseBody注解,Spring返回值到响应体。如果这样做的话,Spring将根据请求中的 Content-Type header(私下)使用 HTTP Message converters 来将domain对象转换为响应体。
ResponseEntity 是一个真实数据.它代表了整个 HTTP 响应(response). 它的好处是你可以控制任何对象放到它内部。
你可以指定状态码、头信息和响应体。它包含你想要构建HTTP Response 的信息。
@PathVariable 此注解意味着一个方法参数应该绑定到一个url模板变量[在'{}'里的一个]中
一般来说你,要实现REST API in Spring 4 需要了解@RestController , @RequestBody, ResponseEntity 和 @PathVariable 这些注解 .另外, spring 也提供了一些支持类帮助你实现一些可定制化的东西。
MediaType : 带着 @RequestMapping 注解,通过特殊的控制器方法你可以额外指定,MediaType来生产或者消耗。
发布和测试此API
- <dependency>
- <groupId>com.fasterxml.jackson.core</groupId>
- <artifactId>jackson-databind</artifactId>
- <version>2.5.3</version>
- </dependency
因为Spring在类路径发现了这个库,它调用了内置的MappingJackson2HttpMessageConverter 转换器将响应(对象集合)转换为JSON格式。
根据RestTemplate 写REST Client
RestTemplate随之出现。RestTemplate 提供了高级方法,来响应者6种主要的HTTP方法。
HTTP 方法和对应的 RestTemplate方法:
- HTTP GET : getForObject, getForEntity
- HTTP PUT : put(String url, Object request, String…urlVariables)
- HTTP DELETE : delete
- HTTP POST : postForLocation(String url, Object request, String… urlVariables), postForObject(String url, Object request, ClassresponseType, String… uriVariables)
- HTTP HEAD : headForHeaders(String url, String… urlVariables)
- HTTP OPTIONS : optionsForAllow(String url, String… urlVariables)
- HTTP PATCH and others : exchange execute
定义 Rest client , 定义REST services
- package com.websystique.springmvc;
- import java.net.URI;
- import java.util.LinkedHashMap;
- import java.util.List;
- import org.springframework.web.client.RestTemplate;
- import com.websystique.springmvc.model.User;
- public class SpringRestTestClient {
- public static final String REST_SERVICE_URI = "http://localhost:8080/Spring4MVCCRUDRestService";
- /* GET */
- @SuppressWarnings("unchecked")
- private static void listAllUsers(){
- System.out.println("Testing listAllUsers API-----------");
- RestTemplate restTemplate = new RestTemplate();
- List<LinkedHashMap<String, Object>> usersMap = restTemplate.getForObject(REST_SERVICE_URI+"/user/", List.class);
- if(usersMap!=null){
- for(LinkedHashMap<String, Object> map : usersMap){
- System.out.println("User : id="+map.get("id")+", Name="+map.get("name")+", Age="+map.get("age")+", Salary="+map.get("salary"));;
- }
- }else{
- System.out.println("No user exist----------");
- }
- }
- /* GET */
- private static void getUser(){
- System.out.println("Testing getUser API----------");
- RestTemplate restTemplate = new RestTemplate();
- User user = restTemplate.getForObject(REST_SERVICE_URI+"/user/1", User.class);
- System.out.println(user);
- }
- /* POST */
- private static void createUser() {
- System.out.println("Testing create User API----------");
- RestTemplate restTemplate = new RestTemplate();
- User user = new User(0,"Sarah",51,134);
- URI uri = restTemplate.postForLocation(REST_SERVICE_URI+"/user/", user, User.class);
- System.out.println("Location : "+uri.toASCIIString());
- }
- /* PUT */
- private static void updateUser() {
- System.out.println("Testing update User API----------");
- RestTemplate restTemplate = new RestTemplate();
- User user = new User(1,"Tomy",33, 70000);
- restTemplate.put(REST_SERVICE_URI+"/user/1", user);
- System.out.println(user);
- }
- /* DELETE */
- private static void deleteUser() {
- System.out.println("Testing delete User API----------");
- RestTemplate restTemplate = new RestTemplate();
- restTemplate.delete(REST_SERVICE_URI+"/user/3");
- }
- /* DELETE */
- private static void deleteAllUsers() {
- System.out.println("Testing all delete Users API----------");
- RestTemplate restTemplate = new RestTemplate();
- restTemplate.delete(REST_SERVICE_URI+"/user/");
- }
- public static void main(String args[]){
- listAllUsers();
- getUser();
- createUser();
- listAllUsers();
- updateUser();
- listAllUsers();
- deleteUser();
- listAllUsers();
- deleteAllUsers();
- listAllUsers();
- }
- }
重启服务器,运行上面的程序。
- Testing listAllUsers API-----------
- User : id=1, Name=Sam, Age=30, Salary=70000.0
- User : id=2, Name=Tom, Age=40, Salary=50000.0
- User : id=3, Name=Jerome, Age=45, Salary=30000.0
- User : id=4, Name=Silvia, Age=50, Salary=40000.0
- Testing getUser API----------
- User [id=1, name=Sam, age=30, salary=70000.0]
- Testing create User API----------
- Location : http://localhost:8080/Spring4MVCCRUDRestService/user/5
- Testing listAllUsers API-----------
- User : id=1, Name=Sam, Age=30, Salary=70000.0
- User : id=2, Name=Tom, Age=40, Salary=50000.0
- User : id=3, Name=Jerome, Age=45, Salary=30000.0
- User : id=4, Name=Silvia, Age=50, Salary=40000.0
- User : id=5, Name=Sarah, Age=51, Salary=134.0
- Testing update User API----------
- User [id=1, name=Tomy, age=33, salary=70000.0]
- Testing listAllUsers API-----------
- User : id=1, Name=Tomy, Age=33, Salary=70000.0
- User : id=2, Name=Tom, Age=40, Salary=50000.0
- User : id=3, Name=Jerome, Age=45, Salary=30000.0
- User : id=4, Name=Silvia, Age=50, Salary=40000.0
- User : id=5, Name=Sarah, Age=51, Salary=134.0
- Testing delete User API----------
- Testing listAllUsers API-----------
- User : id=1, Name=Tomy, Age=33, Salary=70000.0
- User : id=2, Name=Tom, Age=40, Salary=50000.0
- User : id=4, Name=Silvia, Age=50, Salary=40000.0
- User : id=5, Name=Sarah, Age=51, Salary=134.0
- Testing all delete Users API----------
- Testing listAllUsers API-----------
- No user exist----------
完整的例子
更新pom.xml添加项目依赖
- <project xmlns="http://maven.apache.org/POM/4.0.0" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
- xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 http://maven.apache.org/maven-v4_0_0.xsd">
- <modelVersion>4.0.0</modelVersion>
- <groupId>com.websystique.springmvc</groupId>
- <artifactId>Spring4MVCCRUDRestService</artifactId>
- <packaging>war</packaging>
- <version>1.0.0</version>
- <name>Spring4MVCCRUDRestService Maven Webapp</name>
- <properties>
- <springframework.version>4.2.0.RELEASE</springframework.version>
- <jackson.version>2.5.3</jackson.version>
- </properties>
- <dependencies>
- <dependency>
- <groupId>org.springframework</groupId>
- <artifactId>spring-webmvc</artifactId>
- <version>${springframework.version}</version>
- </dependency>
- <dependency>
- <groupId>org.springframework</groupId>
- <artifactId>spring-tx</artifactId>
- <version>${springframework.version}</version>
- </dependency>
- <dependency>
- <groupId>com.fasterxml.jackson.core</groupId>
- <artifactId>jackson-databind</artifactId>
- <version>${jackson.version}</version>
- </dependency>
- <dependency>
- <groupId>javax.servlet</groupId>
- <artifactId>javax.servlet-api</artifactId>
- <version>3.1.0</version>
- </dependency>
- </dependencies>
- <build>
- <pluginManagement>
- <plugins>
- <plugin>
- <groupId>org.apache.maven.plugins</groupId>
- <artifactId>maven-compiler-plugin</artifactId>
- <version>3.2</version>
- <configuration>
- <source>1.7</source>
- <target>1.7</target>
- </configuration>
- </plugin>
- <plugin>
- <groupId>org.apache.maven.plugins</groupId>
- <artifactId>maven-war-plugin</artifactId>
- <version>2.4</version>
- <configuration>
- <warSourceDirectory>src/main/webapp</warSourceDirectory>
- <warName>Spring4MVCCRUDRestService</warName>
- <failOnMissingWebXml>false</failOnMissingWebXml>
- </configuration>
- </plugin>
- </plugins>
- </pluginManagement>
- <finalName>Spring4MVCCRUDRestService</finalName>
- </build>
- </project>
User Service
- package com.websystique.springmvc.service;
- import java.util.List;
- import com.websystique.springmvc.model.User;
- public interface UserService {
- User findById(long id);
- User findByName(String name);
- void saveUser(User user);
- void updateUser(User user);
- void deleteUserById(long id);
- List<User> findAllUsers();
- void deleteAllUsers();
- public boolean isUserExist(User user);
- }
- package com.websystique.springmvc.service;
- import java.util.ArrayList;
- import java.util.Iterator;
- import java.util.List;
- import java.util.concurrent.atomic.AtomicLong;
- import org.springframework.stereotype.Service;
- import org.springframework.transaction.annotation.Transactional;
- import com.websystique.springmvc.model.User;
- @Service("userService")
- @Transactional
- public class UserServiceImpl implements UserService{
- private static final AtomicLong counter = new AtomicLong();
- private static List<User> users;
- static{
- users= populateDummyUsers();
- }
- public List<User> findAllUsers() {
- return users;
- }
- public User findById(long id) {
- for(User user : users){
- if(user.getId() == id){
- return user;
- }
- }
- return null;
- }
- public User findByName(String name) {
- for(User user : users){
- if(user.getName().equalsIgnoreCase(name)){
- return user;
- }
- }
- return null;
- }
- public void saveUser(User user) {
- user.setId(counter.incrementAndGet());
- users.add(user);
- }
- public void updateUser(User user) {
- int index = users.indexOf(user);
- users.set(index, user);
- }
- public void deleteUserById(long id) {
- for (Iterator<User> iterator = users.iterator(); iterator.hasNext(); ) {
- User user = iterator.next();
- if (user.getId() == id) {
- iterator.remove();
- }
- }
- }
- public boolean isUserExist(User user) {
- return findByName(user.getName())!=null;
- }
- private static List<User> populateDummyUsers(){
- List<User> users = new ArrayList<User>();
- users.add(new User(counter.incrementAndGet(),"Sam",30, 70000));
- users.add(new User(counter.incrementAndGet(),"Tom",40, 50000));
- users.add(new User(counter.incrementAndGet(),"Jerome",45, 30000));
- users.add(new User(counter.incrementAndGet(),"Silvia",50, 40000));
- return users;
- }
- public void deleteAllUsers() {
- users.clear();
- }
- }
Model (模型)类
- package com.websystique.springmvc.model;
- public class User {
- private long id;
- private String name;
- private int age;
- private double salary;
- public User(){
- id=0;
- }
- public User(long id, String name, int age, double salary){
- this.id = id;
- this.name = name;
- this.age = age;
- this.salary = salary;
- }
- public long getId() {
- return id;
- }
- public void setId(long id) {
- this.id = id;
- }
- public String getName() {
- return name;
- }
- public void setName(String name) {
- this.name = name;
- }
- public int getAge() {
- return age;
- }
- public void setAge(int age) {
- this.age = age;
- }
- public double getSalary() {
- return salary;
- }
- public void setSalary(double salary) {
- this.salary = salary;
- }
- @Override
- public int hashCode() {
- final int prime = 31;
- int result = 1;
- result = prime * result + (int) (id ^ (id >>> 32));
- return result;
- }
- @Override
- public boolean equals(Object obj) {
- if (this == obj)
- return true;
- if (obj == null)
- return false;
- if (getClass() != obj.getClass())
- return false;
- User other = (User) obj;
- if (id != other.id)
- return false;
- return true;
- }
- @Override
- public String toString() {
- return "User [id=" + id + ", name=" + name + ", age=" + age
- + ", salary=" + salary + "]";
- }
- }
- package com.websystique.springmvc.configuration;
- import org.springframework.context.annotation.ComponentScan;
- import org.springframework.context.annotation.Configuration;
- import org.springframework.web.servlet.config.annotation.EnableWebMvc;
- @Configuration
- @EnableWebMvc
- @ComponentScan(basePackages = "com.websystique.springmvc")
- public class HelloWorldConfiguration {
- }
初始化类
- package com.websystique.springmvc.configuration;
- import org.springframework.web.servlet.support.AbstractAnnotationConfigDispatcherServletInitializer;
- public class HelloWorldInitializer extends AbstractAnnotationConfigDispatcherServletInitializer {
- @Override
- protected Class<?>[] getRootConfigClasses() {
- return new Class[] { HelloWorldConfiguration.class };
- }
- @Override
- protected Class<?>[] getServletConfigClasses() {
- return null;
- }
- @Override
- protected String[] getServletMappings() {
- return new String[] { "/" };
- }
- }
为你的REST API添加CORS支持
” XMLHttpRequest cannot load http://abc.com/bla. Origin http://localhost:12345 is not allowed by Access-Control-Allow-Origin.”
- package com.websystique.springmvc.configuration;
- import java.io.IOException;
- import javax.servlet.Filter;
- import javax.servlet.FilterChain;
- import javax.servlet.FilterConfig;
- import javax.servlet.ServletException;
- import javax.servlet.ServletRequest;
- import javax.servlet.ServletResponse;
- import javax.servlet.http.HttpServletResponse;
- public class CORSFilter implements Filter {
- public void doFilter(ServletRequest req, ServletResponse res, FilterChain chain) throws IOException, ServletException {
- System.out.println("Filtering on...........................................................");
- HttpServletResponse response = (HttpServletResponse) res;
- response.setHeader("Access-Control-Allow-Origin", "*");
- response.setHeader("Access-Control-Allow-Methods", "POST, GET, PUT, OPTIONS, DELETE");
- response.setHeader("Access-Control-Max-Age", "3600");
- response.setHeader("Access-Control-Allow-Headers", "x-requested-with");
- chain.doFilter(req, res);
- }
- public void init(FilterConfig filterConfig) {}
- public void destroy() {}
- }
- package com.websystique.springmvc.configuration;
- import javax.servlet.Filter;
- import org.springframework.web.servlet.support.AbstractAnnotationConfigDispatcherServletInitializer;
- public class HelloWorldInitializer extends AbstractAnnotationConfigDispatcherServletInitializer {
- @Override
- protected Class<?>[] getRootConfigClasses() {
- return new Class[] { HelloWorldConfiguration.class };
- }
- @Override
- protected Class<?>[] getServletConfigClasses() {
- return null;
- }
- @Override
- protected String[] getServletMappings() {
- return new String[] { "/" };
- }
- @Override
- protected Filter[] getServletFilters() {
- Filter [] singleton = { new CORSFilter()};
- return singleton;
- }
- }
REST API 开发的更多相关文章
- 第六代智能英特尔® 酷睿™ 处理器图形 API 开发人员指南
欢迎查看第六代智能英特尔® 酷睿™ 处理器图形 API 开发人员指南,该处理器可为开发人员和最终用户提供领先的 CPU 和图形性能增强.各种新特性和功能以及显著提高的性能. 本指南旨在帮助软件开发人员 ...
- 天气预报API开发
天气预报API开发 一. 寻觅篇 最近想要跟着视频练习一下利用API开发一个天气预报系统,就在网上找了一下可以用的API,结果好多都已经失效了... 1. 百度车联网天气预报 ...
- 高性能PHP框架thinkphp5.0.0 Beta发布-为API开发而设计
ThinkPHP V5.——为API开发而设计的高性能框架 ThinkPHP5..0版本是一个颠覆和重构版本,采用全新的架构思想,引入了很多的PHP新特性,优化了核心,减少了依赖,实现了真正的惰性加载 ...
- ASP.NET Core Web API 开发-RESTful API实现
ASP.NET Core Web API 开发-RESTful API实现 REST 介绍: 符合REST设计风格的Web API称为RESTful API. 具象状态传输(英文:Representa ...
- 基于.Net Framework 4.0 Web API开发(2):ASP.NET Web APIs 参数传递方式详解
概述: ASP.NET Web API 的好用使用过的都知道,没有复杂的配置文件,一个简单的ApiController加上需要的Action就能工作.调用API过程中参数的传递是必须的,本节就来谈谈 ...
- API 开发实践
整个2015年,如果要给自己打上一个标签的话,那应该就是 API. 在各个不同的系统中定制各种 API 框架. 在做商城对接各种电商 ERP 的 API 开发中,我采用的是兼容SHOPEX 的 API ...
- 报表引擎API开发入门— EJB程序数据源
我们前面讲了几个数据源,今天我们来讲一下EJB数据源,这篇讲完我们数据源这部分就讲完了.数据连接不需要直接访问数据库,而是使用EJB做为数据源.FR通过定义程序数据集使用EJB的相关类获取到EJB数据 ...
- Rest API 开发 学习笔记(转)
Rest API 开发 学习笔记 概述 REST 从资源的角度来观察整个网络,分布在各处的资源由URI确定,而客户端的应用通过URI来获取资源的表示方式.获得这些表徵致使这些应用程序转变了其状态.随着 ...
- Windows下mock环境搭建-加速项目Api开发
本文来自http://blog.csdn.net/liuxian13183/ ,引用必须注明出处! 公司进行技术部拆分,以项目制作为新的开发模式,前端+移动端+后端,于是加速Api开发变得很有必要,准 ...
- 淘宝API开发系列---阿里.聚石塔.开放平台的使用
好久没有继续跟进淘宝的API使用了,有很多做相关应用的同行都来咨询,很多都因为自己开发工作比较忙而没有来得及好的处理,前几天,有一个朋友叫帮忙指导如何使用淘宝API,由于原来有一些成熟的例子应用,因此 ...
随机推荐
- 测试SDWebImage淡入淡出效果在UITableView中的重用显示问题
测试SDWebImage淡入淡出效果在UITableView中的重用显示问题 这个是在上一篇教程的基础上所添加的测试环节! 效果图(从效果图中看是没有任何重用问题的): 源码: ImageCell.h ...
- Linux 用户和用户组详解
用户分类 超级用户:UID范围 0 root用户:uid=0(root) gid=0(root) groups=0(root) 普通用户:由管理员创建,UID范围(500-65535) --> ...
- 硬盘上的一些算法小题目||and今天看了下林锐的书以及gdb调试 及一些变成算法小题目
gdb调试:观察点,断点,事件捕捉点.step 进入函数,next 跳过函数,until 跳出循环,finish 结束函数 林锐:书后试题 & c++的对象模型图 看了二叉树的非递归遍历, 链 ...
- caioj 1172 poj 2823 单调队列过渡题
给定一个n个数的数列,从左至右输出每个长度为m的数列段内的最大数. 输入:第一行两个整数n和m( 1<= n <= 20 0000,m<=n).下来给出n个整数. 输出:一行一个整数 ...
- (转)获取安卓iOS上的微信聊天记录、通过Metasploit控制安卓
在这篇文章中我们将讨论如何获取安卓.苹果设备中的微信聊天记录,并演示如何利用后门通过Metasploit对安卓设备进行控制.文章比较基础.可动手性强,有设备的童鞋不妨边阅读文章边操作,希望能激发大家对 ...
- Selenium2+python-unittest之装饰器(@classmethod)
原文地址:http://www.cnblogs.com/yoyoketang/p/6685416.html 前言 前面讲到unittest里面setUp可以在每次执行用例前执行,这样有效的减少了代码量 ...
- MySQL(五)SELECT语句执行顺序
上一篇讲述了Oracle的SELECT语法的执行顺序,这篇讲述MySQL的SELECT语法的执行顺序.MySQL的SELECT语法的执行顺序和Oracle的基本相同,只是增加了MySQL独有的LIMI ...
- jq的innerWidth()遇到的坑
innerWidth()在元素隐藏的时候是取不到值的,但是取到的是元素的内部尺寸,包括padding和content值,,如果元素隐藏了之后他的content就为空,值为0,所以只有等到元素显示之后再 ...
- CentOS 7中为Yum设置代理
公司给的Linux机器,默认没给联网,然后安装Docker时流程走不下去,找IT半天没人回,然后我就自己折腾,各种配置系统代理,结果并没有成功,最后发现yum可以单独为yum设置代理,方式如下: YU ...
- Java开发工程师基础Math,Random,Scanner类的使用
Math类的使用(重点) (1)数学操作类:该类没有构造函数,方法均为静态的 (2)掌握内容 A:成员变量 **E:比任何其他值都更接近e(即自然对数的底数)的double值. **PI:比任何其他值 ...