昨晚搞得很郁闷,好好的项目,放到客户的服务器居然404,发现应该是服务器不支持pathinfo方式,但至今也没有找到确切的原因(毕竟也用的apache,怎会不支持pathinfo?.htaccess里面配置AcceptPathInfo也不行),在网上也找了,居然也有人重写的,不过他重写的是Config类,而且还重写了其他几个类,汗。。,搞不懂,ci支持helper的优先级的嘛,方便就一个函数搞定。。【后来发现,form_validation.php配置文件,他也是要通过URI获取来的rsegment来判断uri合法性,所以没办法,使用这个后,验证表单时要加上配置文件所指定的验证规则:如$this->form_validation->run('login/do_login')】

自己application下的common_helper.php:

 

/**
 * zcs=重写ci的site_url
 * [开启do_enable_query_strings配置]
 * 支持原本的index.php/xx/xx/p1/v1/p2/v2方式转换为index.php?c=xx&m=xx&p1=v1&p2=v2
 * @param $uri
 * @return unknown_type
 */
function site_url($uri = ''){
	$CI =& get_instance();
	if (is_array($uri) || $uri == '' || !$CI->config->item('do_enable_query_strings')){
		return $CI->config->site_url($uri);
	}else{
		//zcs=>解析PATHINFO方式为正常方式,ci用uri传递函数参数的方式则不可取了
		$uri = trim($uri, '/');
		$uri_arr = explode('/', $uri);
		$param_len = count($uri_arr);
		$c = '?'.$CI->config->item('controller_trigger').'='.$uri_arr[0];
		$m = (($param_len >= 2) ? '&'.$CI->config->item('function_trigger').'='.$uri_arr[1] : '');
		$uri = $c.$m;
		for ($i = 2; $i < $param_len; $i++){
			$uri .= (($i%2) ? '=' : '&');
			$uri .= $uri_arr[$i];
		}
		return $CI->config->slash_item('base_url').$CI->config->item('index_page').trim($uri, '/');
	}
}

 

另外用到了我自己的一个配置项,方便配置这种特有的方式,避免冲突:

[config.php]

 

/*
|--------------------------------------------------------------------------
| 将所有site_url中使用的index.php/xx/xx/p1/v1/p2/v2方式转换为?c=xx&m=xx&p1=v1&p2=v2
|--------------------------------------------------------------------------
|1、此配置依赖于common_helper.php中重写的site_url函数
|2、转换后需要配置enable_query_strings开启,否则ci不允许
|
*/
$config['do_enable_query_strings']	= TRUE;

然后可以方便地转换了,不过ci的uri传函数参数方式就不行了,个人觉得也最好不要使用这种方式,直接还是用原始的GET传参吧,毕竟这种有局限

posted on 2010-12-04 00:12  重生  阅读(4087)  评论(0编辑  收藏  举报