本文将带您了解关于discuz电脑版、手机版去除标题title中的PoweredbyDiscuz!教程的新内容,同时我们还将为您解释discuz去掉标题版权的相关知识,另外,我们还将为您提供关于Dis
本文将带您了解关于discuz电脑版、手机版去除标题title中的PoweredbyDiscuz!教程的新内容,同时我们还将为您解释discuz去掉标题版权的相关知识,另外,我们还将为您提供关于Discuz & UCenter 修改手记,discuz论坛、Discuz & UCenter 修改手记,discuz论坛_PHP教程、discuz 7.0 推荐Discuz!5的PHP代码高亮显示与实现可运行代码、discuz x1.5 discuz程序的PHP加密函数原理分析的实用信息。
本文目录一览:- discuz电脑版、手机版去除标题title中的PoweredbyDiscuz!教程(discuz去掉标题版权)
- Discuz & UCenter 修改手记,discuz论坛
- Discuz & UCenter 修改手记,discuz论坛_PHP教程
- discuz 7.0 推荐Discuz!5的PHP代码高亮显示与实现可运行代码
- discuz x1.5 discuz程序的PHP加密函数原理分析
discuz电脑版、手机版去除标题title中的PoweredbyDiscuz!教程(discuz去掉标题版权)
discuz! X3.2电脑版、手机版默认模板去除标题title中的Powered by discuz!的方法电脑版:打开 /template/default/common/header_common.htm 文件
找到
$navtitle - $_G['setting']['bbname'] - Powered by discuz!
删除Powered by discuz!即可
手机版之标准版:
打开 /template/default/mobile/common/header.htm 文件
找到
$navtitle - $_G['setting']['bbname'] - {lang waptitle} - Powered by discuz!
删除Powered by discuz!即可
手机版之触屏版:
打开 /template/default/touch/common/header.htm 文件
找到
$navtitle - $_G['setting']['bbname'] - {lang waptitle} - Powered by discuz!
删除Powered by discuz!即可
查看更多 discuz教程 discuz模板 discuz插件
Discuz & UCenter 修改手记,discuz论坛
discuz & ucenter 修改手记,discuz论坛
最近在整java和ucenter的东西,受限于项目架构需要,无法完全以ucenter为中心,所以在对接过程中遇到了许多不愉快的事情。经历多番研究,终于解决了其中了两个大问题,现记录下来,以备日后查看。
一、解决email必须填写的问题
项目并不要求用户注册时填写email,但UCENTER API要求必须输入email才可以通过验证,不得已必须得修改UCENTER代码才能绕过。以下是改动的代码:
/uc_server/control/user.php 69行:
<span>1</span> <span>//</span><span> NOTE: 解决email必须填写的问题 </span><span>2</span> <span>//if(($status = $this->_check_email($email)) < 0) { </span><span>3</span> <span>// return $status; </span><span>4</span> <span>//}</span>
二、解决用户必须手工登录1次论坛的问题
由于BBS屏蔽了DISCUZ自带的注册、登录、找密等操作,所以必须要实现单点登录。当中遇到了一个非常蛋疼的问题:主站注册的账户同步到UCENTER之后,UCENTER并不会通知其他应用,也就是说默认情况下,其他应用(包括DISCUZ在内)无法在新用户注册之后立即更新用户列表。细细研究之后发现,DISCUZ是在本地注册、登录等事件中才会与UCENTER同步。这导致了,在主站新注册的用户,无法在BBS单点登录成功——因为在BBS中根本不存在这个用户。解决的方法有两个,一是用户手工登录一次BBS,BBS自带的机制会自动将用户信息从UCENTER同步过来;二是修改DISCUZ系统代码,在单点登录请求时自动同步用户数据。在权衡了各方面因素之后,决定采用第二套方案。以下是改动的代码:
/api/uc.php 192行:
<span> 1</span> <span>//</span><span> NOTE 解决用户必须手工登录1次论坛的问题</span> <span> 2</span> <span>$member</span> = getuserbyuid(<span>$uid</span>, 1<span>); </span><span> 3</span> <span> 4</span> <span>if</span> (!<span>$member</span><span>) { </span><span> 5</span> <span>$init_arr</span> = <span>explode</span>('','', <span>$_G</span>[''initcredits''<span>]); </span><span> 6</span> <span>$groupid</span> = <span>$_G</span>[''regverify''] ? 8 : <span>$_G</span>[''newusergroupid''<span>]; </span><span> 7</span> <span> 8</span> C::t(''common_member'')->insert(<span>$uid</span>, <span>$get</span>[''username''], <span>md5</span>(random(10)), <span>$get</span>[''email''], <span>$_G</span>[''clientip''], <span>$groupid</span>, <span>$init_arr</span><span>); </span><span> 9</span> <span>10</span> <span>$member</span> = getuserbyuid(<span>$uid</span>, 1<span>); </span><span>11</span> <span>} </span><span>12</span> <span>13</span> <span>if</span>(<span>$member</span><span>) { </span><span>14</span> dsetcookie(''auth'', authcode("<span>$member</span>[password]\t<span>$member</span>[uid]", ''ENCODE''), <span>$cookietime</span><span>); </span><span>15</span> }
Discuz & UCenter 修改手记,discuz论坛_PHP教程
discuz & ucenter 修改手记,discuz论坛
最近在整java和ucenter的东西,受限于项目架构需要,无法完全以ucenter为中心,所以在对接过程中遇到了许多不愉快的事情。经历多番研究,终于解决了其中了两个大问题,现记录下来,以备日后查看。
一、解决email必须填写的问题
项目并不要求用户注册时填写email,但UCENTER API要求必须输入email才可以通过验证,不得已必须得修改UCENTER代码才能绕过。以下是改动的代码:
/uc_server/control/user.php 69行:
<span>1</span> <span>//</span><span> NOTE: 解决email必须填写的问题 </span><span>2</span> <span>//if(($status = $this->_check_email($email)) < 0) { </span><span>3</span> <span>// return $status; </span><span>4</span> <span>//}</span>
二、解决用户必须手工登录1次论坛的问题
由于BBS屏蔽了DISCUZ自带的注册、登录、找密等操作,所以必须要实现单点登录。当中遇到了一个非常蛋疼的问题:主站注册的账户同步到UCENTER之后,UCENTER并不会通知其他应用,也就是说默认情况下,其他应用(包括DISCUZ在内)无法在新用户注册之后立即更新用户列表。细细研究之后发现,DISCUZ是在本地注册、登录等事件中才会与UCENTER同步。这导致了,在主站新注册的用户,无法在BBS单点登录成功——因为在BBS中根本不存在这个用户。解决的方法有两个,一是用户手工登录一次BBS,BBS自带的机制会自动将用户信息从UCENTER同步过来;二是修改DISCUZ系统代码,在单点登录请求时自动同步用户数据。在权衡了各方面因素之后,决定采用第二套方案。以下是改动的代码:
立即学习“PHP免费学习笔记(深入)”;
/api/uc.php 192行:
<span> 1</span> <span>//</span><span> NOTE 解决用户必须手工登录1次论坛的问题</span> <span> 2</span> <span>$member</span> = getuserbyuid(<span>$uid</span>, 1<span>); </span><span> 3</span> <span> 4</span> <span>if</span> (!<span>$member</span><span>) { </span><span> 5</span> <span>$init_arr</span> = <span>explode</span>('','', <span>$_G</span>[''initcredits''<span>]); </span><span> 6</span> <span>$groupid</span> = <span>$_G</span>[''regverify''] ? 8 : <span>$_G</span>[''newusergroupid''<span>]; </span><span> 7</span> <span> 8</span> C::t(''common_member'')->insert(<span>$uid</span>, <span>$get</span>[''username''], <span>md5</span>(random(10)), <span>$get</span>[''email''], <span>$_G</span>[''clientip''], <span>$groupid</span>, <span>$init_arr</span><span>); </span><span> 9</span> <span>10</span> <span>$member</span> = getuserbyuid(<span>$uid</span>, 1<span>); </span><span>11</span> <span>} </span><span>12</span> <span>13</span> <span>if</span>(<span>$member</span><span>) { </span><span>14</span> dsetcookie(''auth'', authcode("<span>$member</span>[password]\t<span>$member</span>[uid]", ''ENCODE''), <span>$cookietime</span><span>); </span><span>15</span> }
discuz 7.0 推荐Discuz!5的PHP代码高亮显示与实现可运行代码
discuz!5.0论坛显示风格的php代码高亮显示插件,
把php代码进行语法着色,喜欢PHP的同志可以轻松的看代码啦。
同时添加了html代码运行功能。
此插件是在以前某位同志发布的Discuz!4的php代码高亮显示基础之上修改完成。
另外,本人的php学习进入了停滞状态,
希望有人能帮助我走出php的学习困境
My QQ:5642382 我的QQ群:2577162
功能:发贴时使用[php]php代码[/php]标记来高亮显示php代码,
使用[runcode]Html代码[/runcode]标记来运行HTML代码(在客户端运行非服务器)。
插件添加步骤如下:
1.修改include/common.js
查找
复制代码 代码如下:
立即学习“PHP免费学习笔记(深入)”;
function copycode(obj) {
var rng = document.body.createTextRange();
rng.moveToElementText(obj);
rng.scrollIntoView();
rng.select();
rng.execCommand("Copy");
rng.collapse(false);
}
在这个函数结束的下面添加:
复制代码 代码如下:
立即学习“PHP免费学习笔记(深入)”;
function runCode(obj) {
var winname = window.open('''', "_blank", '''');
winname.document.open(''text/html'', ''replace'');
winname.document.writeln(obj.value);
winname.document.close();
}
function saveCode(obj) {
var winname = window.open('''', ''_blank'', ''top=10000'');
winname.document.open(''text/html'', ''replace'');
winname.document.writeln(obj.value);
winname.document.execCommand(''saveas'','''',''code.htm'');
winname.close();
}
2.修改include/discuzcode.func.php
查找
复制代码 代码如下:
立即学习“PHP免费学习笔记(深入)”;
$discuzcodes[''codecount'']++;
return "[\tDISCUZ_CODE_$discuzcodes[pcodecount]\t]";
}
(注:也可以用Editplus直接查找到代码的第110行来进行下面的添加)
在下面继续添加:
复制代码 代码如下:
立即学习“PHP免费学习笔记(深入)”;
//------- 添加 [runcode] Html代码 [/runcode] 来运行Html代码
function runcodedisp($code) {
global $discuzcodes;
$discuzcodes[''pcodecount'']++;
$code = htmlspecialchars(str_replace(''\\"'', ''"'', preg_replace("/^[\n\r]*(.+?)[\n\r]*$/is", "\\1", $code)));
$discuzcodes[''codehtml''][$discuzcodes[''pcodecount'']] = "
/g,''''); delpost.runcode$discuzcodes[codecount] .value = ffcod; 提示:您可以先修改部分代码再运行
";
$discuzcodes[''codecount'']++;
return "[\tDISCUZ_CODE_$discuzcodes[pcodecount]\t]";
}
//------- 添加 [php] php代码 [/php] 来高亮显示php代码,进行php语法着色
function phpcodedisp($code) {
global $discuzcodes;
$discuzcodes[''pcodecount'']++;
$code = phphighlite(str_replace("\\\"", "\"", $code));
$discuzcodes[''codehtml''][$discuzcodes[''pcodecount'']] = "
";
$discuzcodes[''codecount'']++;
return "[\tDISCUZ_CODE_$discuzcodes[pcodecount]\t]";
}
function phphighlite($code) {
if(!strpos($code,"\n") && !strpos($code,'''') && substr($code,0,2) != '''') {
$code = '''';
$addedtags = 1;
}
ob_start();
$oldlevel = error_reporting(0);
highlight_string($code);
error_reporting($oldlevel);
$buffer = ob_get_contents();
ob_end_clean();
if ($addedtags) {
$openingpos = strpos($buffer, '''');
$closingpos = strrpos($buffer, ''?'');
$buffer = substr($buffer, 0, $openingpos).substr($buffer, $openingpos+5, $closingpos-($openingpos+5)).substr($buffer, $closingpos+5);
}
$buffer = str_replace(''"'', "\"", $buffer);
$buffer = str_replace(''
'', '''', $buffer);
return $buffer;
}
//------- 结束
3.继续修改include/discuzcode.func.php
查找
复制代码 代码如下:
立即学习“PHP免费学习笔记(深入)”;
$message = preg_replace("/\s*\[code\](.+?)\[\/code\]\s*/ies", "codedisp(''\\1'')", $message);
在其下面继续添加:
复制代码 代码如下:
立即学习“PHP免费学习笔记(深入)”;
//------- runcode
$message = preg_replace("/\s*\[runcode\](.+?)\[\/runcode\]\s*/ies", "runcodedisp(''\\1'')", $message);
//------- php
$message = preg_replace("/\s*\[php\](.+?)\[\/php\]\s*/ies", "phpcodedisp(''\\1'')", $message);
以上就介绍了discuz 7.0 推荐Discuz!5的PHP代码高亮显示与实现可运行代码,包括了discuz 7.0方面的内容,希望对PHP教程有兴趣的朋友有所帮助。
discuz x1.5 discuz程序的PHP加密函数原理分析
原理如下,假如:
加密
明文:1010 1001
密匙:1110 0011
密文:0100 1010
得出密文0100 1010,解密之需和密匙异或下就可以了
解密
密文:0100 1010
密匙:1110 0011
明文:1010 1001
并没有什么高深的算法,密匙重要性很高,所以,关键在于怎么生成密匙。
那我们一起看下康盛的authcode怎么做的吧
复制代码 代码如下:
// 参数解释
// $string: 明文 或 密文
// $operation:DECODE表示解密,其它表示加密
// $key: 密匙
// $expiry:密文有效期
function authcode($string, $operation = ''DECODE'', $key = '''', $expiry = 0) {
// 动态密匙长度,相同的明文会生成不同密文就是依靠动态密匙
$ckey_length = 4;
// 密匙
$key = md5($key ? $key : $GLOBALS[''discuz_auth_key'']);
// 密匙a会参与加解密
$keya = md5(substr($key, 0, 16));
// 密匙b会用来做数据完整性验证
$keyb = md5(substr($key, 16, 16));
// 密匙c用于变化生成的密文
$keyc = $ckey_length ? ($operation == ''DECODE'' ? substr($string, 0, $ckey_length):
substr(md5(microtime()), -$ckey_length)) : '''';
// 参与运算的密匙
$cryptkey = $keya.md5($keya.$keyc);
$key_length = strlen($cryptkey);
// 明文,前10位用来保存时间戳,解密时验证数据有效性,10到26位用来保存$keyb(密匙b),解密时会通过这个密匙验证数据完整性
// 如果是解码的话,会从第$ckey_length位开始,因为密文前$ckey_length位保存 动态密匙,以保证解密正确
$string = $operation == ''DECODE'' ? base64_decode(substr($string, $ckey_length)) :
sprintf(''%010d'', $expiry ? $expiry + time() : 0).substr(md5($string.$keyb), 0, 16).$string;
$string_length = strlen($string);
$result = '''';
$box = range(0, 255);
$rndkey = array();
// 产生密匙簿
for($i = 0; $i $rndkey[$i] = ord($cryptkey[$i % $key_length]);
}
// 用固定的算法,打乱密匙簿,增加随机性,好像很复杂,实际上对并不会增加密文的强度
for($j = $i = 0; $i $j = ($j + $box[$i] + $rndkey[$i]) % 256;
$tmp = $box[$i];
$box[$i] = $box[$j];
$box[$j] = $tmp;
}
// 核心加解密部分
for($a = $j = $i = 0; $i $a = ($a + 1) % 256;
$j = ($j + $box[$a]) % 256;
$tmp = $box[$a];
$box[$a] = $box[$j];
$box[$j] = $tmp;
// 从密匙簿得出密匙进行异或,再转成字符
$result .= chr(ord($string[$i]) ^ ($box[($box[$a] + $box[$j]) % 256]));
}
if($operation == ''DECODE'') {
// substr($result, 0, 10) == 0 验证数据有效性
// substr($result, 0, 10) - time() > 0 验证数据有效性
// substr($result, 10, 16) == substr(md5(substr($result, 26).$keyb), 0, 16) 验证数据完整性
// 验证数据有效性,请看未加密明文的格式
if((substr($result, 0, 10) == 0 || substr($result, 0, 10) - time() > 0) &&
substr($result, 10, 16) == substr(md5(substr($result, 26).$keyb), 0, 16)) {
return substr($result, 26);
} else {
return '''';
}
} else {
// 把动态密匙保存在密文里,这也是为什么同样的明文,生产不同密文后能解密的原因
// 因为加密后的密文可能是一些特殊字符,复制过程可能会丢失,所以用base64编码
return $keyc.str_replace(''='', '''', base64_encode($result));
}
}
但是有点遗憾,这个函数所有权属于康盛创想,并不能自由使用的
以上就介绍了discuz x1.5 discuz程序的PHP加密函数原理分析,包括了discuz x1.5方面的内容,希望对PHP教程有兴趣的朋友有所帮助。
今天的关于discuz电脑版、手机版去除标题title中的PoweredbyDiscuz!教程和discuz去掉标题版权的分享已经结束,谢谢您的关注,如果想了解更多关于Discuz & UCenter 修改手记,discuz论坛、Discuz & UCenter 修改手记,discuz论坛_PHP教程、discuz 7.0 推荐Discuz!5的PHP代码高亮显示与实现可运行代码、discuz x1.5 discuz程序的PHP加密函数原理分析的相关知识,请在本站进行查询。
本文标签: