@RequestBody @ResponseBody

@RequestBody

	1) 该注解用于读取 Request 请求的 body 部分数据,使用系统默认配置的 HttpMessageConverter 进行解析,
把相应的数据绑定到要返回的对象上。 2) 再把 HttpMessageConverter 返回的对象数据绑定到 controller 中方法的参数上。 application/json, application/xml:这些格式的数据,必须使用 @RequestBody 来处理。 @ResponseBody 将 Controller 的方法返回的对象通过适当的转换器转换为指定的格式后,
写入到 response 对象的 body 区,通常用来返回 JSON数据 或 XML。 注意:在使用 @RequestMapping 后,返回值通常解析为跳转路径,
但是加上 @ResponseBody 后返回结果不会被解析为跳转路径,而是直接写入 HTTP response body 中。
比如异步获取 json 数据,加上 @ResponseBody 后,会直接返回 json 数据。

JPQL查询

查询一个对象的所有属性时,并不能像 MySQL 那样使用 * 号标志。

"SELECT c.name, c.age FROM Customer c WHERE c.id > ?"

默认情况下, 若只查询部分属性, 则将返回 Object[] 类型的结果,或者 Object[] 类型的 List。

也可以在实体类中创建对应的构造器, 然后再 JPQL 语句中利用对应的构造器返回实体类的对象。

"SELECT new Customer(c.name, c.age) FROM Customer c WHERE c.id > ?"

JPA Specifications

使用Specifications,必须继承JpaSpecificationExecutor接口。

public interface Specification<T> extends Serializable {
@Nullable
Predicate toPredicate(Root<T> root, CriteriaQuery<?> query, CriteriaBuilder criteriaBuilder);
} Root:
是查询结果的一个实体对象,也就是查询结果返回的主要对象。 CriteriaQuery:
是JPA标准,主要是构建查询条件的。
里面的方法都是各种查询方式:distinct、select、where、groupby、having、orderby。 CriteriaBuilder:
返回Predicate接口,其中包含between、gt(大于)、lt(小于)、not等操作。 Root:查询哪个表
CriteriaQuery:查询哪些字段,排序是什么
CriteriaBuilder:字段之间是什么关系,如何生成一个查询条件,每一个查询条件都是什么方式
Predicate:单独每一条查询条件的详细描述

URLDecoder URLEncoder 解决Get请求中文乱码问题

URLDecoder 和 URLEncoder:
用于完成普通字符串 和 application/x-www-form-urlencoded MIME 字符串之间的相互转换。 浏览器中的地址栏中所输入的URL包含中文字符时(一般是URL携带的参数),
浏览器首先会将这些中文字符进行编码然后再发送给服务器。
实际上,浏览器会将它们转换为 application/x-www-form-urlencoded MIME 字符串。 URLEncoder类包含一个encode(String s,String enc)静态方法:
它可以将普通字符串转换成application/x-www-form-urlencoded MIME字符串。 URLDecoder类包含一个decode(String s,String enc)静态方法:
它可以将application/x-www-form-urlencoded MIME字符串转成普通字符串; 在 Java 代码中的 URLEncoder.encode() 的字符串
可以在 JS 中用 decodeURIComponent() 还原成字符串。 在 JS 中用 encodeURIComponent() 的参数
可以在 Java 代码中可以用 URLDecoder.decode(request.getParameter("param"),"UTF-8") 还原成字符串。

RSS

RSS 指 Really Simple Syndication(真正简易联合)
RSS 使您有能力聚合(syndicate)网站的内容
RSS 定义了非常简单的方法来共享和查看标题和内容
RSS 文件可被自动更新
RSS 允许为不同的网站进行视图的个性化
RSS 使用 XML 编写 通过 RSS feed(RSS 通常被称为 News feed 或 RSS feed),
用户们可以使用 RSS 聚合器来更快地检查您的网站更新(RSS 聚合器是用来聚集并分类 RSS feed 的网站或软件)。 feed:
信源,英文是feed。
信息发布网站将网站全部或者部分信息整合到一个 RSS 文件中,这个文件就被称之为 feed 。
信源中包含的数据都是标准的 XML 格式,不但能直接被其他站点调用,也能在其他的终端和服务中使用。

RSS Feed

<?xml version="1.0" encoding="UTF-8" ?>
<rss version="2.0"> <channel>
<title>博客标题</title>
<link>博客地址</link>
<description>网站描述</description>
<item>
<title>第一篇</title>
<description>摘要</description>
<author>作者</author>
<pubDate>发布时间</pubDate>
<link>链接</link>
</item>
</channel> </rss> <channel> 元素用于描述 RSS feed。<channel> 元素有三个必需的子元素:
<title> - 定义频道的标题
<link> - 定义到达频道的超链接
<description> - 描述此频道 每个 <channel> 元素可拥有一个或多个 <item> 元素,用于定义 RSS feed 中的一篇文章或 "story"。 <item> 元素拥有三个必需的子元素:
<title> - 定义项目的标题
<link> - 定义到达项目的超链接
<description> - 描述此项目

发布自己的 RSS feed

只能当其他人能够找到您的 RSS 文档时,它才是有用的。

把您的 RSS 发布到 Web 上:

	1. 编写 RSS feed,为您的 RSS feed 命名(请注意文件必须有 .xml 的后缀)。

	2. 验证您的 RSS 文件(可以在 http://www.feedvalidator.org 找到很好的验证器)。

	3. 把 RSS 文件上传到您的 web 服务器上的 web 目录。

	4. 把页面按钮 RSS Logo 或  XML Logo 添加指向 RSS 文件的链接。

网站更新内容后,需要即时更新 RSS feed。

Halo(十二)的更多相关文章

  1. 前端开发中SEO的十二条总结

    一. 合理使用title, description, keywords二. 合理使用h1 - h6, h1标签的权重很高, 注意使用频率三. 列表代码使用ul, 重要文字使用strong标签四. 图片 ...

  2. CRL快速开发框架系列教程十二(MongoDB支持)

    本系列目录 CRL快速开发框架系列教程一(Code First数据表不需再关心) CRL快速开发框架系列教程二(基于Lambda表达式查询) CRL快速开发框架系列教程三(更新数据) CRL快速开发框 ...

  3. 我的MYSQL学习心得(十二) 触发器

    我的MYSQL学习心得(十二) 触发器 我的MYSQL学习心得(一) 简单语法 我的MYSQL学习心得(二) 数据类型宽度 我的MYSQL学习心得(三) 查看字段长度 我的MYSQL学习心得(四) 数 ...

  4. Web 前端开发精华文章推荐(jQuery、HTML5、CSS3)【系列十二】

    2012年12月12日,[<Web 前端开发人员和设计师必读文章>系列十二]和大家见面了.梦想天空博客关注 前端开发 技术,分享各种增强网站用户体验的 jQuery 插件,展示前沿的 HT ...

  5. 第十二章Fundamental Data Types 基本数据类型

    目录: 12.1 数值概论 12.2整数 12.3浮点数 12.4 字符和字符串 12.5布尔变量 12.6枚举类型 12.7具名常量 12.8数组 12.9创建你自己的类型 12.1   数值概论 ...

  6. [分享] IT天空的二十二条军规

    Una 发表于 2014-9-19 20:25:06 https://www.itsk.com/thread-335975-1-1.html IT天空的二十二条军规 第一条.你不是什么都会,也不是什么 ...

  7. Bootstrap <基础三十二>模态框(Modal)插件

    模态框(Modal)是覆盖在父窗体上的子窗体.通常,目的是显示来自一个单独的源的内容,可以在不离开父窗体的情况下有一些互动.子窗体可提供信息.交互等. 如果您想要单独引用该插件的功能,那么您需要引用  ...

  8. Bootstrap <基础二十二>超大屏幕(Jumbotron)

    Bootstrap 支持的另一个特性,超大屏幕(Jumbotron).顾名思义该组件可以增加标题的大小,并为登陆页面内容添加更多的外边距(margin).使用超大屏幕(Jumbotron)的步骤如下: ...

  9. Bootstrap <基础十二>下拉菜单(Dropdowns)

    Bootstrap 下拉菜单.下拉菜单是可切换的,是以列表格式显示链接的上下文菜单.这可以通过与 下拉菜单(Dropdown) JavaScript 插件 的互动来实现. 如需使用下列菜单,只需要在 ...

  10. AngularJs的UI组件ui-Bootstrap分享(十二)——Rating

    Rating是一个用于打分或排名的控件.看一个最简单的例子: <!DOCTYPE html> <html ng-app="ui.bootstrap.demo" x ...

随机推荐

  1. python之_init_()方法浅析

    在python的类中,我们会经常看到一个类中的一个方法_init_(self) ,比如下面的一个例子: class Student(object): def __init__(self,name,we ...

  2. CSU 1547 Rectangle(dp、01背包)

    题目链接:http://acm.csu.edu.cn/csuoj/problemset/problem?pid=1547 Description Now ,there are some rectang ...

  3. if isinstance(obj, int):

    http://legacy.python.org/dev/peps/pep-0008/ Object type comparisons should always use isinstance() i ...

  4. ruby异常处理

    begin # 这段代码抛出的异常将被下面的 rescue 子句捕获 rescue # 这个块将捕获所有类型的异常 retry # 这将把控制移到 begin 的开头 end

  5. 使用 wx.navigateBack返回页面并携带参数的处理方式

    getAddressList (){ let that = this; util.request(api.AddressList).then(function (res) { if (res.errn ...

  6. Git012--Bug&Feature分支

    一.Git--Bug分支 软件开发中,bug就像家常便饭一样.有了bug就需要修复,在Git中,由于分支是如此的强大,所以,每个bug都可以通过一个新的临时分支来修复,修复后,合并分支,然后将临时分支 ...

  7. 方法重载(overload)与方法重写(override)

    一.方法重载: 在同一个类中,允许存在一个及以上的同名方法,只要他们的参数列表不同(参数的个数或者参数的类型不同)即可.注意方法重载与返回值类型.访问权限修饰符.和抛出的异常无关.重载是在本类中,与继 ...

  8. luoguP3391[模板]文艺平衡树(Splay) 题解

    链接一下题目:luoguP3391[模板]文艺平衡树(Splay) 平衡树解析 这里的Splay维护的显然不再是权值排序 现在按照的是序列中的编号排序(不过在这道题目里面就是权值诶...) 那么,继续 ...

  9. seaborn教程3——数据集的分布可视化

    原文转载:https://segmentfault.com/a/1190000015006667 Seaborn学习大纲 seaborn的学习内容主要包含以下几个部分: 风格管理 绘图风格设置 颜色风 ...

  10. #python# 代理过程中遇到的error

    做一下总结 urllib.error.HTTPError: HTTP Error 503: Too many open connections TimeoutError: [WinError 1006 ...