Category Archives: Hello World

Hello World

cakephp路由配置

cakephp的默认路由配置是直接根据url寻找对应的controller和下面的action,如果想改url,而不改controller名字,可以修改app/config/roures.php

比如,现在有这样一个需求:访问mobile_controller的url默认是xxx/mobile/xxx,需要改为xxx/m/xxx,则需要再roures.php添加配置:
Router::connect(‘/m’, array(‘controller’ => ‘mobile’, ‘action’ => ‘index’));
Router::connect(‘/m/:action/*’, array(‘controller’ => ‘mobile’, ‘action’ => ‘index’));
Hello World

EL表达式语言语法及其他

${表达式}

EL的前世今生

EL即Expression Language,是一种简单的数据访问语言,最初是JSTL1.0中定义的,从JSTL1.1开始,Sun公司将其从JSTL分离出来,成为JSP2.0规范中单独的一部分,并增加了很多新的特性。

最基本的应用

${user}

等效于jsp脚本表达式:<%= pageContext.findAttribute(“user”) %>

访问javaBean中的属性对象中的属性

${lesson.student.id}

访问有序集合中的元素

${teacherIds[2]}

执行基本的关系运算、逻辑运算和算术运算

${1 > (5 / 2)}

输出结果:false

使用自定义函数完成一些复杂功能

${xyz:filter(“<img/>”)}

其中,xyz:filter是自定义函数,“<img/>”是传递给这个自定义函数的参数

EL表达式中使用一些列隐含对象

如:pageContext、cookie

在页面上输出”${“

“\” + “$”,即”\${xyz}”可以输出” ${xyz}”

另外,${“${”}可以输出”${”

忽略页面中所有的EL表达式

<%@ page isELIgnored=”true” %>

EL的基本语法

标识符(变量和自定义函数名称):有任意顺序的大小写字母、数值、下划线组成,不能以数值开头,不能使用EL中的保留字,布恩那个使用EL隐含对象的标识符,不能使用的符号:单引号,双引号,减号,正斜杠(/)

保留字:and,eq,or等

EL中的常量

布尔:true/false

整形:与java中的十进制整形常量相同

浮点数:取值范围同Double,可以使用指数形式(如1.2E4)

字符串:用单引号双引号引起来的一连串的字符

关于内部单/双引号的转义(\)规则:

只有用单引号引起来的字符串,内部的单引号才需要转义,双引号不需要转义

同理,只有双引号…

Null:

EL中的变量

El表达式语言的核心概念就是将变量映射到一个对象上,其中的变量不用先定义,而是直接使用,EL API中定义了javax.servlet.jsp.el.VariableResolver类来将一个变量名映射到某个对象上,他实现了隐含对象的映射,还实现了非隐含对象的变量标识符与各个域范围内的属性值的映射。

如果EL表达式中包含变量名不对应EL隐含对象的标识符,则EL引擎将调用pageContext.findAttribute()方法在各个域中(page,request,session,applecation)依次查找变量名的属性值,如果找到这个属性,则返回找到的属性值,如果没有找到,则返回null。

Hello World

jquery.ui初探__基于draggable()和droppable()的鼠标拖动选择器

今天下午一直在研究jquery ui,做了一个类似复选框功能的鼠标拖动选择器,主要功能如下面图中所示,相关的代码在最后,如果想看效果,只要将下面横线内的代码黏贴到记事本中,保存为html格式,然后用浏览器打开就好了:

图1.初始的页面效果,可以将绿色的字母拖入右侧的方框内

图2.拖动一个带选项到方框内

图3.第一个选项拖动完成

图4.最多可以选择4个,且不可以有重复选项

图5.也可以随时点击下方链接,查看当前选择情况

一下是页面代码:

—————————————————————————

[script src=”http://code.jquery.com/jquery-latest.js”>
[script type=”text/javascript”]//var a_this;//这个用来记录选择项的显示值
var a_type = new Array();//这个,用来记录选项的type值,可以表示将向服务器提交的项目
var is_choose;//记录当前的选项是否已被选择
var is_into;//检查是否已被拖动到选项区
var max_choose = 4;//最多的可选数量
var view_count = $(‘#changed’);
var count = 0;
$(document).ready(function(){
a_changed();
$(“.abc”).draggable({
helper: ‘clone’,
start : function(e, ui){//这里可以使start,也可以是drag,表示拖动开始或拖动过程中将执行的逻辑,但不能使用stop,因为如果使用stop,其中的逻辑会在droppable()的drop后执行,i记录的就是上一次拖动的东西
is_choose = 0;
is_into = 0;
a_this = this;
for(var j=0; j
if(a_type[j]==this){
is_choose = 1;//检查当前选项是否已选择
}
}
},
stop : function(e, ui){//这里一定要用stop,stop是一个时刻,而drag是一个时间段,如果用drag会造成多次赋值,用start的话,如果没有拖动到预选区,会将不想要的结果传递到预选辅助内
is_into ++;
canChoose();
}
});
$(“.drop”).droppable({
accept: “.abc”,
activeClass: ‘droppable-active’,
hoverClass: ‘droppable-hover’,
drop: function() {
is_into++;
}
});
});
function canChoose(){
count = a_type.length + 1;
if(is_choose == 0 && is_into == 2 && count <= max_choose){
a_changed();
$(“.drop”).append(”
” + a_this.text);
a_type[a_type.length] = a_this;
}
}
function a_changed(){//提示信息的显示
if(count == 0){
$(“#changed”).text(“(请将您的选项拖到这里)”);
}else if(count < max_choose){ $(“#changed”).text(“(已选”+count+”项,还可选”+(max_choose-count)+”项)”); }else{ $(“#changed”).text(“(选项已满!)”); } } function ssss(){ var sf=”已选数量:” + a_type.length; if(a_type.length > 0){
sf+=”,包括:”
for(var j=0; j

[script src=”http://dev.jquery.com/view/tags/ui/latest/ui/ui.core.js”>

查看当前选项

<a type=”jkl1″>AA</a>
<a type=”jkl2″>BB</a>
<a type=”jkl3″>CC</a>
<a type=”jkl4″>DD</a>
<a type=”jkl5″>EE</a>
<a type=”jkl6″>FF</a>
<a type=”jkl7″>GG</a>
<a type=”jkl8″>HH</a>
<a type=”jkl9″>II</a>
<a type=”jkl10″>JJ</a>

您当前的选择:

参考资料:http://docs.jquery.com/UI/Droppables

Hello World 他山石

jQuery Ajax 全解析

jQuery确实是一个挺好的轻量级的JS框架,能帮助我们快速的开发JS应用,并在一定程度上改变了我们写JavaScript代码的习惯。

废话少说,直接进入正题,我们先来看一些简单的方法,这些方法都是对jQuery.ajax()进行封装以方便我们使用的方法,当然,如果要处理复杂的逻辑,还是需要用到jQuery.ajax()的(这个后面会说到).

1. load( url, [data], [callback] ) :载入远程 HTML 文件代码并插入至 DOM 中。

url(String) : 请求的HTML页的URL地址。

data(Map) : (可选参数) 发送至服务器的 key/value 数据。

callback(Callback) : (可选参数) 请求完成时(不需要是success的)的回调函数。

这个方法默认使用 GET 方式来传递的,如果[data]参数有传递数据进去,就会自动转换为POST方式的。jQuery 1.2 中,可以指定选择符,来筛选载入的 HTML 文档,DOM 中将仅插入筛选出的 HTML 代码。语法形如 “url #some > selector”。

这个方法可以很方便的动态加载一些HTML文件,例如表单。

示例代码:

$(".ajax.load").load("http://www.cnblogs.com/QLeelulu/archive/2008/03/30/1130270.html .post",function(responseText, textStatus, XMLHttpRequest){this;//在这里this指向的是当前的DOM对象,即$(".ajax.load")[0]//alert(responseText);//请求返回的内容//alert(textStatus);//请求状态:success,error//alert(XMLHttpRequest);//XMLHttpRequest对象});
这里将显示结果。

注:不知道为什么URL写绝对路径在FF下会出错,知道的麻烦告诉下。下面的get()和post()示例使用的是绝对路径,所以在FF下你将会出错并不会看到返回结果。还有get()和post()示例都是跨域调用的,发现传上来后没办法获取结果,所以把运行按钮去掉了。

2. jQuery.get( url, [data], [callback] ):使用GET方式来进行异步请求

参数:

url(String) : 发送请求的URL地址.

data(Map) : (可选) 要发送给服务器的数据,以 Key/value 的键值对形式表示,会做为QueryString附加到请求URL中。

callback(Function) : (可选) 载入成功时回调函数(只有当Response的返回状态是success才是调用该方法)。

这是一个简单的 GET 请求功能以取代复杂 $.ajax 。请求成功时可调用回调函数。如果需要在出错时执行函数,请使用 $.ajax。示例代码:

$.get("./Ajax.aspx", {Action:"get",Name:"lulu"},function(data, textStatus){//返回的 data 可以是 xmlDoc, jsonObj, html, text, 等等.this;// 在这里this指向的是Ajax请求的选项配置信息,请参考下图alert(data);//alert(textStatus);//请求状态:success,error等等。当然这里捕捉不到error,因为error的时候根本不会运行该回调函数//alert(this);});

点击发送请求:

jQuery.get()回调函数里面的 this ,指向的是Ajax请求的选项配置信息:

image

3. jQuery.post( url, [data], [callback], [type] ) :使用POST方式来进行异步请求

参数:

url(String) : 发送请求的URL地址.

data(Map) : (可选) 要发送给服务器的数据,以 Key/value 的键值对形式表示。

callback(Function) : (可选) 载入成功时回调函数(只有当Response的返回状态是success才是调用该方法)。

type(String) : (可选)官方的说明是:Type of data to be sent。其实应该为客户端请求的类型(JSON,XML,等等)

这是一个简单的 POST 请求功能以取代复杂 $.ajax 。请求成功时可调用回调函数。如果需要在出错时执行函数,请使用 $.ajax。示例代码:

Ajax.aspx:

Response.ContentType = "application/json";Response.Write("{result: '" + Request["Name"] + ",你好!(这消息来自服务器)'}");

jQuery 代码:

$.post("Ajax.aspx", { Action: "post", Name: "lulu" },function(data, textStatus){// data 可以是 xmlDoc, jsonObj, html, text, 等等.//this; // 这个Ajax请求的选项配置信息,请参考jQuery.get()说到的thisalert(data.result);}, "json");

点击提交:

这里设置了请求的格式为”json”:

image

如果你设置了请求的格式为”json”,此时你没有设置Response回来的ContentType 为:Response.ContentType = “application/json”; 那么你将无法捕捉到返回的数据。

注意一下,alert(data.result); 由于设置了Accept报头为“json”,这里返回的data就是一个对象,并不需要用eval()来转换为对象。

4. jQuery.getScript( url, [callback] ) : 通过 GET 方式请求载入并执行一个 JavaScript. 文件

参数

url(String) : 待载入 JS 文件地址。

callback(Function) : (可选) 成功载入后回调函数。

jQuery 1.2 版本之前,getScript. 只能调用同域 JS 文件。 1.2中,您可以跨域调用 JavaScript. 文件。注意:Safari 2 或更早的版本不能在全局作用域中同步执行脚本。如果通过 getScript. 加入脚本,请加入延时函数。

这个方法可以用在例如当只有编辑器focus()的时候才去加载编辑器需要的JS文件.下面看一些示例代码:

加载并执行 test.js。

jQuery 代码:

$.getScript(“test.js”);


加载并执行 AjaxEvent.js ,成功后显示信息。

jQuery 代码:

$.getScript("AjaxEvent.js",function(){alert("AjaxEvent.js 加载完成并执行完成.你再点击上面的Get或Post按钮看看有什么不同?");});

加载完后请重新点击一下上面的 Load 请求看看有什么不同。

jQuery Ajax 事件

Ajax请求会产生若干不同的事件,我们可以订阅这些事件并在其中处理我们的逻辑。在jQuery这里有两种Ajax事件:局部事件 和 全局事件。

局部事件就是在每次的Ajax请求时在方法内定义的,例如:

$.ajax({beforeSend:function(){// Handle the beforeSend event},complete:function(){// Handle the complete event}// ...});

全局事件是每次的Ajax请求都会触发的,它会向DOM中的所有元素广播,在上面 getScript() 示例中加载的脚本就是全局Ajax事件。全局事件可以如下定义:

$("#loading").bind("ajaxSend",function(){$(this).show();}).bind("ajaxComplete",function(){$(this).hide();});

或者:

$("#loading").ajaxStart(function(){$(this).show();});

我们可以在特定的请求将全局事件禁用,只要设置下 global 选项就可以了:

$.ajax({url: "test.html",global:false,// 禁用全局Ajax事件.// ...});

下面是jQuery官方给出的完整的Ajax事件列表:

  • ajaxStart(Global Event)
    This event is broadcast if an Ajax request is started and no other Ajax requests are currently running.

    • beforeSend(Local Event)
      This event, which is triggered before an Ajax request is started, allows you to modify the XMLHttpRequest object (setting additional headers, if need be.)
    • ajaxSend(Global Event)
      This global event is also triggered before the request is run.
    • success(Local Event)
      This event is only called if the request was successful (no errors from the server, no errors with the data).
    • ajaxSuccess(Global Event)
      This event is also only called if the request was successful.
    • error(Local Event)
      This event is only called if an error occurred with the request (you can never have both an error and a success callback with a request).
    • ajaxError(Global Event)
      This global event behaves the same as the local error event.
    • complete(Local Event)
      This event is called regardless of if the request was successful, or not. You will always receive a complete callback, even for synchronous requests.
    • ajaxComplete(Global Event)
      This event behaves the same as the complete event and will be triggered every time an Ajax request finishes.
  • ajaxStop(Global Event)
    This global event is triggered if there are no more Ajax requests being processed.

    具体的全局事件请参考API文档。
    好了,下面开始说jQuery里面功能最强的Ajax请求方法 $.ajax();

  • Hello World

    request.getParameter() 与request.getAttribute()

    一、request.getParameter() 和request.getAttribute() 区别
    (1)request.getParameter()取得是通过容器的实现来取得通过类似post,get等方式传入的数据,request.setAttribute()和getAttribute()只是在web容器内部流转,仅仅是请求处理阶段。
    (2)request.getParameter()方法传递的数据,会从Web客户端传到Web服务器端,代表HTTP请求数据。request.getParameter()方法返回String类型的数据。
    request.setAttribute()和getAttribute()方法传递的数据只会存在于Web容器内部
    还有一点就是,HttpServletRequest类有setAttribute()方法,而没有setParameter()方法。
    拿一个例子来说一下吧,假如两个WEB页面间为链接关系时,就是说要从1.jsp链接到2.jsp时,被链接的是2.jsp可以通过getParameter()方法来获得请求参数.
    假如1.jsp里有

    <form action=”2.jsp” method=”post”> 请输入用户姓名:
    <input name=”username” type=”text” /> <input name=”Submit” type=”submit” value=”提交” /> </form>

    的话在2.jsp中通过request.getParameter(“username”)方法来获得请求参数username:
    < % String username=request.getParameter(“username”); %>
    但是如果两个WEB间为转发关系时,转发目的WEB可以用getAttribute()方法来和转发源WEB共享request范围内的数据,也还是说一个例子吧。
    有1.jsp和2.jsp
    1.jsp希望向2.jsp传递当前的用户名字,如何传递这一数据呢?先在1.jsp中调用如下setAttribute()方法:

    在2.jsp中通过getAttribute()方法获得用户名字:

    二、request.getAttribute()与request.setAttribute()
    request.getAttribute(“nameOfObj”)可得到JSP页面一表单中控件的Value。其实表单控件中的Object的 name与value是存放在一个哈希表中的,所以在这里给出Object的name会到哈希表中找出对应它的value。
    而不同页面间传值使用request.setAttribute(position, nameOfObj)时,只会从a.jsp到b.jsp一次传递,之后这个request就会失去它的作用范围,再传就要再设一个 request.setAttribute()。而使用session.setAttribute()会在一个过程中始终保有这个值。

    P.S.:JavaScript与JSP中不能相互传值,因为JavaScript运行在客户端,而JSP运行在服务器端。若想使它们之间可以相互传递参数,可以在JSP中设置一个hidden控件,用它的value结合上面所说的用法来传递所需的数值。

    Hello World

    使用SecureCRT连接VMWare_Linux

    1. 安装SecureCRT和VMware workstation,并在VMware中安装Linux系统.

    2. 将虚拟机网卡调至“桥接(Bridge)”状态,并勾选真机本地连接属性中的虚拟机桥接协议。

    3. 修改Linux设置文件,主要涉及启动模式、防火墙策略、字符类型、主机名.

    1). vi /etc/inittab    修改Linux启动模式: 3 initdefault    如果是SUSE,则yast->Security and Users->Firewall->Allowed Services->ssh

    2). vi /etc/sysconfig/selinux   禁用本地策略应用: SELINUX=disabledvi

    3). /etc/sysconfig/i18n         修改默认字符

    4). #vi /etc/sysconfig/network     修改主机名 如果是SUSE:则修改:/etc/sysconfig/network/ifcfg-eth-id文件: 配置静态网络地址 BOOTPROTO=’static’ BROADCAST=” ETHTOOL_OPTIONS=” IPADDR=’192.168.149.128′ MTU=” NAME=’AMD PCnet – Fast 79C971′ NETMASK=’255.255.255.0′ NETWORK=” REMOTE_IPADDR=” STARTMODE=’auto’ UNIQUE=’rBUF.weGuQ9ywYPF’ USERCONTROL=’no’ _nm_name=’bus-pci-0000:00:11.0′

    5). reboot

    4. 启动SecureCRT,准备连接

    启动,并点击“快速连接”按钮进行配置: 协议:SSH2, 端口:22, 用户名:root, 防火墙:无.

    Hello World

    html textarea 标签回车符的处理

    html中通<textarea>标签提交的内容会将回车转变成”rn”,再将提交的内容放入<textarea>标签中显示时,回车符会还原成正常的换行。

    但当带有”rn”的字符串放在html的普通文本域中显示时 ,原来的换行效果会转变成空格,因此,需要在显示前将字符串中的”rn”替换为”</br>”。

    另外,还有一点需要注意:EL表达式会将”</br>”换行符转变成”&lt;/br&gt;”,”&lt;”和”&gt;”分别对应”<“和”>”,也就是说,到了页面上,还是显示为”</br>”(呵呵,EL的智能化程度太高了),为了补救这一点,需要使用jsp标签(<%= %>)来进行显示。

    所以当需要在普通文本域中显示由<textarea>提交的内容时,可以直接在数据库里存储不经过处理的字符串,而只在显示前将”rn”替换为”</br>”,然后在页面上使用<%= %>来显示这些内容.