- Golang Channel
PandaSkr
golang
Channel解析1.Channel源码分析1.1Channel数据结构typehchanstruct{qcountuint//channel的元素数量dataqsizuint//channel循环队列长度bufunsafe.Pointer//指向循环队列的指针elemsizeuint16//元素大小closeduint32//channel是否关闭0-未关闭elemtype*_type//元素类
- iOS——atomic、nonatomic、assign、_unsafe_unretain
糸师凛
ioscocoamacos
atomic和nonatomic在iOS开发中,当你定义一个属性时,编译器会自动为你生成一个带下划线的成员变量(实例变量)以及对应的getter和setter方法。如果你使用atomic修饰这个属性,那么编译器在生成setter和getter方法时,会在这些方法的内部实现中加入加锁操作。但是加锁只能保证getter和setter方法内部的线程安全,并不能保证对该属性的所有操作都是线程安全的。具体的
- php操作mysql防止sql注入(合集)
get200
mysqlmysql注入
本文将从sql注入风险说起,并且比较addslashes、mysql_escape_string、mysql_real_escape_string、mysqli和pdo的预处理的区别。当一个变量从表单传入到php,需要查询mysql的话,需要进行处理。举例:$unsafe_variable=$_POST[‘user_input’];mysqli_query(“INSERTINTOtable(col
- [edge浏览器]网站使用的是 HSTS。网络错误和攻击通常是暂时的,因此该页面以后可能会恢复正常。
冰淇淋烤布蕾
edge
问题访问网站是这样的解决办法在当前页面直接输入thisisunsafe(不是地址栏,直接就打字就可以)然后就神奇地进去了原因了解主要看这两个博客[问题解决][edge]你现在无法访问XXX.com,因为网站使用的是HSTS。网络错误和攻击通常是暂时的,因此该页面以后可能会恢复正常。_因为网站使用的是hsts。网络错误和攻击通常是暂时的,因此该页面以后可能会恢复正-CSDN博客(2022年12月)解
- 切片slice的几个要注意的坑
追云的风C
1.切片的底层实现:在runtime包下的slice.go中我们可以看到切片的底层实现。切片其实是一个结构体,对应有三个字段。我要注意的是第一个字段,它是一个数组指针,指向对应的数组存储空间。typeslicestruct{arrayunsafe.Pointer//数组指针lenint//切片长度capint//切片容量}直接声明的切片不能使用下标赋值。因为此时并未分配给切片存储空间。但可以使用a
- Channel(一)chan数据结构
LitC
chan数据结构typehchanstruct{qcountuint//totaldatainthequeuedataqsizuint//sizeofthecircularqueuebufunsafe.Pointer//pointstoanarrayofdataqsizelements环形队列指针elemsizeuint16//队列元素大小closeduint32//标识关闭状态elemtype*
- Mojo实现unsafe pointer详解及接口说明
启航学途
MojomojoMojopointerMojoanypointermojopointer详解mojopointer接口mojo入门mojo基础教程
anypointerImplementagenericunsafepointertype.YoucanimporttheseAPIsfromthememorypackage.Forexample:frommemory.anypointerimportAnyPointerAnyPointerThisisapointertypethatcanpointtoanygenericvaluethatismo
- axios Refused to set unsafe header has been blocked by CORS policy
未金涛
Pythonvue前端爬虫
前言事情是这样的,我准备复制一个资源下载类的网站。第一步肯定是爬取目标网站的资源了。我在用python写爬虫的时候,当我提取完网页中的基础数据之后。就发现,目标网站后面大部分的数据都是通过有规律的api返回的json数据源。这个时候作为一个白飘党,我就在想能不能直接白嫖对面的api,直接拿来用呢?然后,在前端遇到了些问题,我感觉以我现在的技术水准无法解决。前端axios请求示例axios({met
- Go语言:nil切片和空切片
哒嘎哇
GOgolang开发语言后端
参考引用:packagemainimport("fmt""reflect""unsafe")funcmain(){vars1[]ints2:=make([]int,0)s4:=make([]int,0)fmt.Printf("s1pointer:%+v,s2pointer:%+v,s4pointer:%+v,\n",*(*reflect.SliceHeader)(unsafe.Pointer(&s
- go 切片(创建、nil切片、空切片、切片拷贝)
leo_jk
go切片go
一、什么是切片1.切片就是一个“动态”数组,即切片的长度是可以伸缩的。其数据结构是一个结构体,包含三个字段,指向数组的指针、长度、容量。typeslicestruct{arrayunsafe.Pointer//一个指向数组的指针lenintcapint}2.切片的指针指向某个数组,所以它是引用类型。3.代码验证切片是引用类型packagemainimport"fmt"//传入切片funcchang
- 文件绕过-Unsafe Fileuoload
Ryongao
网络安全
文件上传基础什么是文件上传将客户端数据以文件形式封装·通过网络协议发送到服务器端,在服务器端解析数据,最终在服务端硬盘上作为真实的文件保存。通常一个文件以HTTP协议进行上传时,将以POST请求发送至Web服务器,Web服务器收到请求并同意后,用户与Web服务器将建立连接,并传输数据文件上传产生漏洞的原因文件上传漏洞危害上传文件的时候,如果服务器端脚本语言未对上传的文件进行严格的验证和过滤,就容易
- 无锁类原理详解与使用,无锁算法详解,全是干货
纵然间
Javajava开发语言
目录编辑一、无锁类的原理详解1.1CAS1.2CPU指令二、无锁类的使用2.1AtomicInteger2.1.1概述2.1.2主要接口2.1.3主要接口实现2.2Unsafe2.2.1概述2.2.3主要接口2.3AtomicReference2.3.1概述2.3.2主要接口2.4AtomicStampedReference2.4.1概述2.4.2主要接口2.5AtomicIntegerArray
- Netty源码系列 之 ChannelPipeline & IO处理回顾 源码
etcEriksen
Netty源码java后端netty
目录ChannelPipeline【包含AbstractUnsafe.write的源码流程,比之前更加深化了,必看】ChannelPipeline概念回顾ChannelPipeline的创建Inbound(输入Handler)所对应的事件传播Outbound(输出Handler)所对应的事件传播【包含AbstractUnsafe.write的源码流程,比之前更加深化了,必看】ChannelPipe
- 从零开始学howtoheap:fastbins的double-free攻击实操3
网络安全我来了
逆向二进制Re网络安全安全系统安全安全架构
how2heap是由shellphish团队制作的堆利用教程,介绍了多种堆利用技术,后续系列实验我们就通过这个教程来学习。环境可参见从零开始配置pwn环境:优化pwn虚拟机配置支持libc等指令-CSDN博客1.fastbins的double-free攻击这个程序展示了怎样利用free改写全局指针chunk0_ptr达到任意内存写的目的,即unsafeunlink。2.unsafeunlink程序
- 查看内存工具
Abner_XuanYuan
importFoundationpublicenumMemAlign:Int{caseone=1,two=2,four=4,eight=8}privatelet_EMPTY_PTR=UnsafeRawPointer(bitPattern:0x1)!///辅助查看内存的小工具类publicstructMems{privatestaticfunc_memStr(_ptr:UnsafeRawPointe
- python调用golang的函数
风中孤狐
golanggolangpython开发语言
python调用golangpython调用golang脚本,中间需要通过cgo进行golang部分需要先导入cgo和一些标准库import("fmt""quote/node_exporter""unsafe")/*#cgoCFLAGS:#include#include*/import"C"//需要紧挨着暴露一些golang函数注意://和export必须要紧挨着如果需要传参的话,需要用c的类型字
- Rust初体验感想
勤奋的程哥
rust
最近花了半个月的时间入门了Rust编程语言,简要的写一下对这门语言的感想。对于困扰于C/C++编程中经常出现的解引用空指针、解引用野指针、内存多次释放这些常见的bug的我来说,Rust的出现完美的解决了以上所有这些问题。首先,Rust中不存在空指针,如果要表示一个值是否存在,只能用Option枚举表示。但unsafe块是个例外。实际上对unsafe块中的指针操作就近乎C中对指针的操作了,因此暂时不
- error C4996: 'scanf': This function or variable may be unsafe.Visual Studio系列编译器使用scanf函数报错
Wang__Peter
IDEvisualstudio
在使用VisualStudio系列编译器使用scanf函数是,是否需到下面这句话呢?errorC4996:‘scanf’:Thisfunctionorvariablemaybeunsafe.Considerusingscanf_sinstead.Todisabledeprecation,use_CRT_SECURE_NO_WARNINGS.Seeonlinehelpfordetails.刚开始使用
- Cesium+MapboxGL+VectorTile -2
seelingzheng
Cesiummvt矢量瓦片
这里主要讲述Cesium通过MapboxGL加载不同服务的情况,分别包括服务部署和发布,以及使用。Cesium+MapboxGL+VectorTile-1调用postgis服务环境搭建,本文基于mac系统来编写brewinstallpostgreserror:Commandfailedwithexit128:git执行brew-v,可以看到fatal:unsaferepository。。。设置sa
- go 内存二进制数据操作
docker真的爽爆了
golang开发语言后端
go内存二进制数据操作go内存二进制数据直接操作以数字类型为例int(linux/macos为int32,windows为int64).如果不清楚可以使用unsafe.Sizeof函数来查看(函数出来的值*8就是int位数)若不使用内存二进制数据操作,你需要在每次获取数字内容时调用binary.BigEndian/LittleEndian的方法来计算出数字大小。而具体是大端还是小端计算由系统决定.
- Netty源码 之 bind绑定流程
etcEriksen
Netty源码java
1.Netty框架总览Netty是一个基于NIO异步通信框架Netty框架是由许多组件,优化的数据结构所构建成。正是通过灵活的组件构建,优化后的数据结构,进而才能保证Netty框架面对高并发场景具有一定的能力1.1Netty相关组件Netty重要的组件有:Channel,EventLoop,Unsafe,ChannelPipeline,Bootstrap,ServerBootstrap等Chann
- 线程安全之可见性(Volatile)和原子性(Atomic)
飞跃南墙的晓M
JAVA基础线程可见性线程原子性
线程安全之可见性(Volatile)和原子性线程之可见性可见性原理分析线程间操作的定义同步的规则定义Happens-before先行发生原则Final修饰符线程可见性总结线程安全之原子性原子操作存在的问题及分析原因示例代码:存在的问题解决办法1)借助sun.misc.Unsafe类:2)使用CAS(Compareandswap)线程之可见性可见性原理分析可见性问题:让一个线程对共享变量的修改,能够
- zabbix配置监控脚本
怡雪~
zabbixzabbix
zabbix配置监控脚本1.修改agent配置文件[root@chang~]#vim/etc/zabbix/zabbix_agentd.conf333行原#UnsafeUserParameters=0修改成UnsafeUserParameters=12.创建脚本与脚本存放目录[root@chang~]#mkdir/etc/zabbix/zabbix_scripts[root@changzabbix
- electron安装
Legendary
1.、安装npm如果你的机器上还没有Node.js®和npm,请安装它们。2、全局安装electronnpminstall-gelectron-prebuiltmac系统需要在管理员权限下安装哟,输好密码就可以开始等他安装了。sudonpminstall-gelectron-prebuilt上面可能会安装不成功,现改为:sudonpminstall-gelectron--unsafe-perm=t
- linux中npm run build 报错处理
浅浅_2d5a
npmrunbuild1、报错internal/modules/cjs/loader.js:883解决cnpminstall@vue/cli-service--unsafe-perm2、ERRORin./node_modules/
[email protected]@css-loader...解决npmrebuildnode-sass3
- golang sudog是什么?
动态一时爽,重构火葬场
langconcurrentgolang开发语言
sudog代表在等待队列中的goroutine,比如channel发送接受。由于goroutine和同步对象的关系是多对多,因此需要sudog映射typesudogstruct{//指向的goroutineg*g//指向前后sudog的指针next*sudogprev*sudog//指向数据elemunsafe.Pointer//dataelement(maypointtostack)//Thef
- 上传文件el-upload
开水没有冬天
上传
文章目录上传报错Blob详解Refusedtogetunsafeheader"content-disposition"xxxx手动触发,用el-upload组件的this.$refs['fileUpload'].submit()触发http-request函数:onUpload(file){console.log('onUpload-custom:file:',file)letformData=n
- C#多线程实践——锁和线程安全
diaobeizhou2045
c#
锁实现互斥的访问,用于确保在同一时刻只有一个线程可以进入特殊的代码片段,考虑下面的类:classThreadUnsafe{staticintval1,val2;staticvoidGo(){if(val2!=0)Console.WriteLine(val1/val2);val2=0;}}这不是线程安全的:如果Go方法被两个线程同时调用,可能会得到在某个线程中除数为零的错误,因为val2可能被一个线
- 导出文件获取文件名时遇到的错误:Refused to get unsafe header
壮语
问题:通过XMLHttpRequest做导出csv文件时候拿不到文件名并报错Refusedtogetunsafeheader"Content-Disposition"解决:跨域问题导致的,需要后端在头信息Access-Control-Expose-Headers中加入Content-Disposition字段参考跨域资源共享CORS详解
- 死磕 java魔法类之Unsafe解析
编程小世界
问题(1)Unsafe是什么?(2)Unsafe只有CAS的功能吗?(3)Unsafe为什么是不安全的?(4)怎么使用Unsafe?简介本章是java并发包专题的第一章,但是第一篇写的却不是java并发包中类,而是java中的魔法类sun.misc.Unsafe。Unsafe为我们提供了访问底层的机制,这种机制仅供java核心类库使用,而不应该被普通用户使用。但是,为了更好地了解java的生态体系
- 分享100个最新免费的高匿HTTP代理IP
mcj8089
代理IP代理服务器匿名代理免费代理IP最新代理IP
推荐两个代理IP网站:
1. 全网代理IP:http://proxy.goubanjia.com/
2. 敲代码免费IP:http://ip.qiaodm.com/
120.198.243.130:80,中国/广东省
58.251.78.71:8088,中国/广东省
183.207.228.22:83,中国/
- mysql高级特性之数据分区
annan211
java数据结构mongodb分区mysql
mysql高级特性
1 以存储引擎的角度分析,分区表和物理表没有区别。是按照一定的规则将数据分别存储的逻辑设计。器底层是由多个物理字表组成。
2 分区的原理
分区表由多个相关的底层表实现,这些底层表也是由句柄对象表示,所以我们可以直接访问各个分区。存储引擎管理分区的各个底层
表和管理普通表一样(所有底层表都必须使用相同的存储引擎),分区表的索引只是
- JS采用正则表达式简单获取URL地址栏参数
chiangfai
js地址栏参数获取
GetUrlParam:function GetUrlParam(param){
var reg = new RegExp("(^|&)"+ param +"=([^&]*)(&|$)");
var r = window.location.search.substr(1).match(reg);
if(r!=null
- 怎样将数据表拷贝到powerdesigner (本地数据库表)
Array_06
powerDesigner
==================================================
1、打开PowerDesigner12,在菜单中按照如下方式进行操作
file->Reverse Engineer->DataBase
点击后,弹出 New Physical Data Model 的对话框
2、在General选项卡中
Model name:模板名字,自
- logbackのhelloworld
飞翔的马甲
日志logback
一、概述
1.日志是啥?
当我是个逗比的时候我是这么理解的:log.debug()代替了system.out.print();
当我项目工作时,以为是一堆得.log文件。
这两天项目发布新版本,比较轻松,决定好好地研究下日志以及logback。
传送门1:日志的作用与方法:
http://www.infoq.com/cn/articles/why-and-how-log
上面的作
- 新浪微博爬虫模拟登陆
随意而生
新浪微博
转载自:http://hi.baidu.com/erliang20088/item/251db4b040b8ce58ba0e1235
近来由于毕设需要,重新修改了新浪微博爬虫废了不少劲,希望下边的总结能够帮助后来的同学们。
现行版的模拟登陆与以前相比,最大的改动在于cookie获取时候的模拟url的请求
- synchronized
香水浓
javathread
Java语言的关键字,可用来给对象和方法或者代码块加锁,当它锁定一个方法或者一个代码块的时候,同一时刻最多只有一个线程执行这段代码。当两个并发线程访问同一个对象object中的这个加锁同步代码块时,一个时间内只能有一个线程得到执行。另一个线程必须等待当前线程执行完这个代码块以后才能执行该代码块。然而,当一个线程访问object的一个加锁代码块时,另一个线程仍然
- maven 简单实用教程
AdyZhang
maven
1. Maven介绍 1.1. 简介 java编写的用于构建系统的自动化工具。目前版本是2.0.9,注意maven2和maven1有很大区别,阅读第三方文档时需要区分版本。 1.2. Maven资源 见官方网站;The 5 minute test,官方简易入门文档;Getting Started Tutorial,官方入门文档;Build Coo
- Android 通过 intent传值获得null
aijuans
android
我在通过intent 获得传递兑现过的时候报错,空指针,我是getMap方法进行传值,代码如下 1 2 3 4 5 6 7 8 9
public
void
getMap(View view){
Intent i =
- apache 做代理 报如下错误:The proxy server received an invalid response from an upstream
baalwolf
response
网站配置是apache+tomcat,tomcat没有报错,apache报错是:
The proxy server received an invalid response from an upstream server. The proxy server could not handle the request GET /. Reason: Error reading fr
- Tomcat6 内存和线程配置
BigBird2012
tomcat6
1、修改启动时内存参数、并指定JVM时区 (在windows server 2008 下时间少了8个小时)
在Tomcat上运行j2ee项目代码时,经常会出现内存溢出的情况,解决办法是在系统参数中增加系统参数:
window下, 在catalina.bat最前面
set JAVA_OPTS=-XX:PermSize=64M -XX:MaxPermSize=128m -Xms5
- Karam与TDD
bijian1013
KaramTDD
一.TDD
测试驱动开发(Test-Driven Development,TDD)是一种敏捷(AGILE)开发方法论,它把开发流程倒转了过来,在进行代码实现之前,首先保证编写测试用例,从而用测试来驱动开发(而不是把测试作为一项验证工具来使用)。
TDD的原则很简单:
a.只有当某个
- [Zookeeper学习笔记之七]Zookeeper源代码分析之Zookeeper.States
bit1129
zookeeper
public enum States {
CONNECTING, //Zookeeper服务器不可用,客户端处于尝试链接状态
ASSOCIATING, //???
CONNECTED, //链接建立,可以与Zookeeper服务器正常通信
CONNECTEDREADONLY, //处于只读状态的链接状态,只读模式可以在
- 【Scala十四】Scala核心八:闭包
bit1129
scala
Free variable A free variable of an expression is a variable that’s used inside the expression but not defined inside the expression. For instance, in the function literal expression (x: Int) => (x
- android发送json并解析返回json
ronin47
android
package com.http.test;
import org.apache.http.HttpResponse;
import org.apache.http.HttpStatus;
import org.apache.http.client.HttpClient;
import org.apache.http.client.methods.HttpGet;
import
- 一份IT实习生的总结
brotherlamp
PHPphp资料php教程php培训php视频
今天突然发现在不知不觉中自己已经实习了 3 个月了,现在可能不算是真正意义上的实习吧,因为现在自己才大三,在这边撸代码的同时还要考虑到学校的功课跟期末考试。让我震惊的是,我完全想不到在这 3 个月里我到底学到了什么,这是一件多么悲催的事情啊。同时我对我应该 get 到什么新技能也很迷茫。所以今晚还是总结下把,让自己在接下来的实习生活有更加明确的方向。最后感谢工作室给我们几个人这个机会让我们提前出来
- 据说是2012年10月人人网校招的一道笔试题-给出一个重物重量为X,另外提供的小砝码重量分别为1,3,9。。。3^N。 将重物放到天平左侧,问在两边如何添加砝码
bylijinnan
java
public class ScalesBalance {
/**
* 题目:
* 给出一个重物重量为X,另外提供的小砝码重量分别为1,3,9。。。3^N。 (假设N无限大,但一种重量的砝码只有一个)
* 将重物放到天平左侧,问在两边如何添加砝码使两边平衡
*
* 分析:
* 三进制
* 我们约定括号表示里面的数是三进制,例如 47=(1202
- dom4j最常用最简单的方法
chiangfai
dom4j
要使用dom4j读写XML文档,需要先下载dom4j包,dom4j官方网站在 http://www.dom4j.org/目前最新dom4j包下载地址:http://nchc.dl.sourceforge.net/sourceforge/dom4j/dom4j-1.6.1.zip
解开后有两个包,仅操作XML文档的话把dom4j-1.6.1.jar加入工程就可以了,如果需要使用XPath的话还需要
- 简单HBase笔记
chenchao051
hbase
一、Client-side write buffer 客户端缓存请求 描述:可以缓存客户端的请求,以此来减少RPC的次数,但是缓存只是被存在一个ArrayList中,所以多线程访问时不安全的。 可以使用getWriteBuffer()方法来取得客户端缓存中的数据。 默认关闭。 二、Scan的Caching 描述: next( )方法请求一行就要使用一次RPC,即使
- mysqldump导出时出现when doing LOCK TABLES
daizj
mysqlmysqdump导数据
执行 mysqldump -uxxx -pxxx -hxxx -Pxxxx database tablename > tablename.sql
导出表时,会报
mysqldump: Got error: 1044: Access denied for user 'xxx'@'xxx' to database 'xxx' when doing LOCK TABLES
解决
- CSS渲染原理
dcj3sjt126com
Web
从事Web前端开发的人都与CSS打交道很多,有的人也许不知道css是怎么去工作的,写出来的css浏览器是怎么样去解析的呢?当这个成为我们提高css水平的一个瓶颈时,是否应该多了解一下呢?
一、浏览器的发展与CSS
- 《阿甘正传》台词
dcj3sjt126com
Part Ⅰ:
《阿甘正传》Forrest Gump经典中英文对白
Forrest: Hello! My names Forrest. Forrest Gump. You wanna Chocolate? I could eat about a million and a half othese. My momma always said life was like a box ochocol
- Java处理JSON
dyy_gusi
json
Json在数据传输中很好用,原因是JSON 比 XML 更小、更快,更易解析。
在Java程序中,如何使用处理JSON,现在有很多工具可以处理,比较流行常用的是google的gson和alibaba的fastjson,具体使用如下:
1、读取json然后处理
class ReadJSON
{
public static void main(String[] args)
- win7下nginx和php的配置
geeksun
nginx
1. 安装包准备
nginx : 从nginx.org下载nginx-1.8.0.zip
php: 从php.net下载php-5.6.10-Win32-VC11-x64.zip, php是免安装文件。
RunHiddenConsole: 用于隐藏命令行窗口
2. 配置
# java用8080端口做应用服务器,nginx反向代理到这个端口即可
p
- 基于2.8版本redis配置文件中文解释
hongtoushizi
redis
转载自: http://wangwei007.blog.51cto.com/68019/1548167
在Redis中直接启动redis-server服务时, 采用的是默认的配置文件。采用redis-server xxx.conf 这样的方式可以按照指定的配置文件来运行Redis服务。下面是Redis2.8.9的配置文
- 第五章 常用Lua开发库3-模板渲染
jinnianshilongnian
nginxlua
动态web网页开发是Web开发中一个常见的场景,比如像京东商品详情页,其页面逻辑是非常复杂的,需要使用模板技术来实现。而Lua中也有许多模板引擎,如目前我在使用的lua-resty-template,可以渲染很复杂的页面,借助LuaJIT其性能也是可以接受的。
如果学习过JavaEE中的servlet和JSP的话,应该知道JSP模板最终会被翻译成Servlet来执行;而lua-r
- JZSearch大数据搜索引擎
颠覆者
JavaScript
系统简介:
大数据的特点有四个层面:第一,数据体量巨大。从TB级别,跃升到PB级别;第二,数据类型繁多。网络日志、视频、图片、地理位置信息等等。第三,价值密度低。以视频为例,连续不间断监控过程中,可能有用的数据仅仅有一两秒。第四,处理速度快。最后这一点也是和传统的数据挖掘技术有着本质的不同。业界将其归纳为4个“V”——Volume,Variety,Value,Velocity。大数据搜索引
- 10招让你成为杰出的Java程序员
pda158
java编程框架
如果你是一个热衷于技术的
Java 程序员, 那么下面的 10 个要点可以让你在众多 Java 开发人员中脱颖而出。
1. 拥有扎实的基础和深刻理解 OO 原则 对于 Java 程序员,深刻理解 Object Oriented Programming(面向对象编程)这一概念是必须的。没有 OOPS 的坚实基础,就领会不了像 Java 这些面向对象编程语言
- tomcat之oracle连接池配置
小网客
oracle
tomcat版本7.0
配置oracle连接池方式:
修改tomcat的server.xml配置文件:
<GlobalNamingResources>
<Resource name="utermdatasource" auth="Container"
type="javax.sql.DataSou
- Oracle 分页算法汇总
vipbooks
oraclesql算法.net
这是我找到的一些关于Oracle分页的算法,大家那里还有没有其他好的算法没?我们大家一起分享一下!
-- Oracle 分页算法一
select * from (
select page.*,rownum rn from (select * from help) page
-- 20 = (currentPag