GVKun编程网logo

discuz电脑版、手机版去除标题title中的PoweredbyDiscuz!教程(discuz去掉标题版权)

13

本文将带您了解关于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电脑版、手机版去除标题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论坛

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论坛_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> }
登录后复制

 

www.bkjia.comtruehttp://www.bkjia.com/PHPjc/930048.htmlTechArticleDiscuz UCenter 修改手记,discuz论坛 最近在整JAVA和UCENTER的东西,受限于项目架构需要,无法完全以UCENTER为中心,所以在对接过程中遇到了许多...

discuz 7.0 推荐Discuz!5的PHP代码高亮显示与实现可运行代码

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'']] = "
PHP代码如下:
$code

"; 
        $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加密函数原理分析

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加密函数原理分析的相关知识,请在本站进行查询。

本文标签: