0

0

谁能帮我把php代码翻译成java的代码。跪求急啊

PHP中文网

PHP中文网

发布时间:2016-05-26 08:18:57

|

1355人浏览过

|

来源于php中文网

原创

谁能帮我把php代码翻译成java的代码。跪求急啊

<?php
class User extends CI_Model {
public function __construct() {
parent::__construct();
defined('RUN_TIME') || define('RUN_TIME', time());
$this->load->model('share');
}

function iflogin($redirect = true, $forward='') {
$this->share->cncn_session_start();
$uid = 0;

//检查是SESSION和COOKIE里的uch_auth是否一致,确保是同一个人
$still_login = false;
if(isset($_SESSION['uch_auth']) && isset($_COOKIE['uch_auth'])
 && ($_SESSION['uch_auth'] == $_COOKIE['uch_auth'])){
$still_login = true;
}
if (isset($_SESSION['uid']) && $_SESSION['uid'] && $still_login) {
$uid = $_SESSION['uid'];

// 没有相关缓存时,做退出的操作,is.cncn.net这里不再做单独的同步退出
if (empty($_COOKIE['uch_auth'])) {
$this->doexit(); 
}

// 每5分钟检测登录期间是否登录进程已被删除(比如其他进程修改了密码)
if ( $this->chk_auth_session($uid) < 0 ) {
$this->doexit(); 
}

// 每60秒更换一次session_id
if ( empty($_SESSION['last_sess_time']) ) {
$_SESSION['last_sess_time'] = time();
} elseif (time() - $_SESSION['last_sess_time'] > 60) {
session_regenerate_id(TRUE);
$_SESSION['last_sess_time'] = time();
}
} else {
if (isset($_COOKIE['uch_auth']) && $_COOKIE['uch_auth']) {
$uid = $this->chk_auth_cookie();
// cookie信息通过了验证时,从cookie恢复登录状态
//------------------------------------------------
if ($uid > 0) {
// 生成session、cookie
$this->set_login($uid);
// 添加登录进程检测相关的session值,以便于后续session进行检测
$_SESSION['last_uc_check_time'] = time();

//------------------------------------------------
} else {
$uid = 0;
}
}
}
if (!$uid && $redirect) {
// 如果是来自ajax的请求,则不做跳转,否则ajax接收到的就是登录页面的html代码
$ajax = $this->input->get_post('ajax');
if (empty($ajax)) {
if (empty($forward)) {
$forward = empty($_SERVER['REQUEST_URI']) ? $this->uri->uri_string : ' 
 $_SERVER['HTTP_HOST']. $_SERVER['REQUEST_URI'];
}
header('Location: '. NET_URL. 'login?forward=' . urlencode($forward));
exit;
} else {
$this->share->cncn_exit('您尚未登录');
}
}
return $uid;
}


/*
* 验证保持登录的cookie是否正确
* @param string $check_type 验证类型(默认为cookie):
* cookie 通过cookie恢复登录时进行的验证
* session 恢复登录后已有session时进行的验证,
这时不验证登录权限的有效时间(因为有可能cookie已失效,但session还在的情况)
* @return mixed 验证登录时,返回该cookie对应的UID,失败时,返回FALSE
*/
function chk_auth_cookie($check_type='cookie') {


if ($check_type == 'cookie') {
if (empty($_COOKIE['uch_auth'])) {
return -1;
} 
$auth_code = $_COOKIE['uch_auth'];
$uid = 0;
} else {
if (empty($_SESSION['uch_auth'])) {
return -1;
} 
$auth_code = $_SESSION['uch_auth'];
$uid = $_SESSION['uid'];
}


$info = array(
'uid' => $uid,
'auth_code' => $auth_code,
'client_ip' => $_SERVER['REMOTE_ADDR'],
'client_info' => $this->get_client_info(),
'user_agent' => $this->get_client_info(FALSE),
'check_type' => $check_type,
);

static $checked;
if ($checked[$auth_code]) {
return $checked[$auth_code];
}

if ( CURRENT_ENV == 'production' ) {
$uc_key = '6e1a233d3c9d4677a617096d70e0c612';
} else {
$uc_key = 'adc0a1d842a7545633b06f451aa3a74c';
}


$info = array(
'sign' => $this->authcode(serialize($info), 'ENCODE', $uc_key),
'from' => 'finance',
);

// 向服务端发起验证请求
if ( CURRENT_ENV == 'production' ) {
$url = 'http://www.cncn.net/homepage/check_uc_session';
} else {
$url = 'http://192.168.1.158:876/homepage/check_uc_session';
}

$info = http_build_query($info);
$ch = curl_init($url);
curl_setopt($ch, CURLOPT_HEADER, 0);
curl_setopt($ch, CURLOPT_RETURNTRANSFER, 1);
curl_setopt($ch, CURLOPT_POST, 1);
curl_setopt($ch, CURLOPT_TIMEOUT, 10);
curl_setopt($ch, CURLOPT_POSTFIELDS, $info);
$r = curl_exec($ch);

curl_close($ch);

$return = unserialize($this->authcode($r, 'DECODE', $uc_key));
 
        if ( empty($return['uid']) ) {
            return '-997';
        }
 
        $uid = $checked[$auth_code] = $return['uid'];
 
        // 验证失败
        if ($uid < 0 ) {
return $uid;
}

// 确定返回的验证结果是否已失效
if ( time() - $return['time'] > 300 ) {
return '-996';
}

return $uid;
}

/*
* 每5分钟检测登录期间是否登录进程已被删除(比如其他进程修改了密码)
* @param int $uid 当前登录用户,保存在session里的uid
*
* @return mixed 验证登录时,返回该cookie对应的UID,失败时,返回FALSE
*/
function chk_auth_session($uid) {
if ( isset($_SESSION['last_uc_check_time']) && time() - $_SESSION['last_uc_check_time'] > 300 ) {
$uid = $this->chk_auth_cookie('session');
            if ( $uid < 0 ) {                    
                // 登录凭证验证失败后,将当前的session删除
                if (session_id() != '') {   // check login被调用多次。。所以这里需要加个判断
                    session_destroy();
                }
            } else {
                $_SESSION['last_uc_check_time'] = time();
            }
        }
        if ( empty($uid) || $uid < 0 ) {
            $uid = 0;
        }
        return $uid;
    }
 
    function authcode($string, $operation = 'DECODE', $key = '', $expiry = 0) {
 
      $ckey_length = 4;
 
      $key = md5($key ? $key : CNCN_API_KEY);
      $keya = md5(substr($key, 0, 16));
      $keyb = md5(substr($key, 16, 16));
      $keyc = $ckey_length ? ($operation == 'DECODE' ? substr($string, 0, $ckey_length): 
      substr(md5(microtime()), -$ckey_length)) : '';
 
      $cryptkey = $keya.md5($keya.$keyc);
      $key_length = strlen($cryptkey);
 
      $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 <= 255; $i++) {
        $rndkey[$i] = ord($cryptkey[$i % $key_length]);
      }
 
      for($j = $i = 0; $i < 256; $i++) {
        $j = ($j + $box[$i] + $rndkey[$i]) % 256;
        $tmp = $box[$i];
        $box[$i] = $box[$j];
        $box[$j] = $tmp;
      }
 
      for($a = $j = $i = 0; $i < $string_length; $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') {
    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 {
    return $keyc.str_replace('=', '', base64_encode($result));
  }
}

/*
* 获取用户的浏览器信息,进行md5加密后返回
*
* @return string
*/
function get_client_info($md5=TRUE) {
$info = array(
'agent' => empty($_SERVER['HTTP_USER_AGENT']) ? 'user_agent' : $_SERVER['HTTP_USER_AGENT'], 
'lang' => empty($_SERVER['HTTP_ACCEPT_LANGUAGE']) ? 'gbk' : strtolower($_SERVER['HTTP_ACCEPT_LANGUAGE']), 
);

$info = join('', $info);

return $md5 ? md5($info) : $info;
}


function doexit() {
$this->share->cncn_session_start();
        $syn = '';
 
        // 彻底清空session
        $_SESSION = array();
        if (ini_get("session.use_cookies")) {
            $params = session_get_cookie_params();
            setcookie(session_name(), '', time() - 42000, $params["path"], $params["domain"], 
            $params["secure"], $params["httponly"]
            );
        }
        session_destroy();
 
        setcookie("uc_auth", "", time() - 3600, '/', config_item('cookiedomain'));
        setcookie("uch_auth", "", time() - 3600, '/', config_item('cookiedomain'));
        echo $syn . '<script>location.href="/";</script>';
exit;
}

/**
* 获取uid获取相应的字段信息
*
* @param mixed $uids 需要获取字段的uid,可为多个,超过一个时用数组传递
* @param $type 需要获取的字段类型
*
*/
public function get_value_byid($uids, $type, $table = 'member') {
if (!$is_array = is_array($uids)) {
$uids = array($uids);
}
$return = array();

$this->cncndb = $this->load->database('cncndb', TRUE);
$query = $this->cncndb->select('uid, ' . $type)->from($table)->where_in('uid', $uids)->get();
foreach ($query->result_array() as $k => $v) {
$return[$v['uid']] = $v[$type];
}

return $is_array ? $return : array_pop($return);
}


/*
* 对用户登录的session进行处理
* @param int $uid 用户编号
* @param string $nickname 用户昵称,如果未传递,则根据uid从member表获取
* @param int $expire cookie保存时间,单位为秒,默认为NULL,即浏览器关闭后就失效
* @return void
*/

function set_login($uid, $nickname = '', $expire = NULL) {
// 保存session
$this->share->cncn_session_start();
        $_SESSION = array();   // 设置登录session前,应该清空之前的session,避免用户会串在一起
        $_SESSION['uid'] = $uid;
        $_SESSION['nickname'] = $nickname;             // 未传递时需要从用户库获取
        $_SESSION['contact_name'] = $contact_name;     // 未传递时需要从用户库获取
        $_SESSION['user_type'] = $user_type;           // 未传递时需要从用户库获取
        $_SESSION['login_time']   = time();
    }
 
}

以上就是谁能帮我把php代码翻译成java的代码。跪求急啊的内容,更多相内容请关注PHP中文网(www.php.cn)!

v0.dev
v0.dev

Vercel推出的AI生成式UI工具,通过文本描述生成UI组件代码

下载
PHP速学教程(入门到精通)
PHP速学教程(入门到精通)

PHP怎么学习?PHP怎么入门?PHP在哪学?PHP怎么学才快?不用担心,这里为大家提供了PHP速学教程(入门到精通),有需要的小伙伴保存下载就能学习啦!

下载

相关标签:

本站声明:本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn

热门AI工具

更多
DeepSeek
DeepSeek

幻方量化公司旗下的开源大模型平台

豆包大模型
豆包大模型

字节跳动自主研发的一系列大型语言模型

通义千问
通义千问

阿里巴巴推出的全能AI助手

腾讯元宝
腾讯元宝

腾讯混元平台推出的AI助手

文心一言
文心一言

文心一言是百度开发的AI聊天机器人,通过对话可以生成各种形式的内容。

讯飞写作
讯飞写作

基于讯飞星火大模型的AI写作工具,可以快速生成新闻稿件、品宣文案、工作总结、心得体会等各种文文稿

即梦AI
即梦AI

一站式AI创作平台,免费AI图片和视频生成。

ChatGPT
ChatGPT

最最强大的AI聊天机器人程序,ChatGPT不单是聊天机器人,还能进行撰写邮件、视频脚本、文案、翻译、代码等任务。

相关专题

更多
pixiv网页版官网登录与阅读指南_pixiv官网直达入口与在线访问方法
pixiv网页版官网登录与阅读指南_pixiv官网直达入口与在线访问方法

本专题系统整理pixiv网页版官网入口及登录访问方式,涵盖官网登录页面直达路径、在线阅读入口及快速进入方法说明,帮助用户高效找到pixiv官方网站,实现便捷、安全的网页端浏览与账号登录体验。

463

2026.02.13

微博网页版主页入口与登录指南_官方网页端快速访问方法
微博网页版主页入口与登录指南_官方网页端快速访问方法

本专题系统整理微博网页版官方入口及网页端登录方式,涵盖首页直达地址、账号登录流程与常见访问问题说明,帮助用户快速找到微博官网主页,实现便捷、安全的网页端登录与内容浏览体验。

135

2026.02.13

Flutter跨平台开发与状态管理实战
Flutter跨平台开发与状态管理实战

本专题围绕Flutter框架展开,系统讲解跨平台UI构建原理与状态管理方案。内容涵盖Widget生命周期、路由管理、Provider与Bloc状态管理模式、网络请求封装及性能优化技巧。通过实战项目演示,帮助开发者构建流畅、可维护的跨平台移动应用。

64

2026.02.13

TypeScript工程化开发与Vite构建优化实践
TypeScript工程化开发与Vite构建优化实践

本专题面向前端开发者,深入讲解 TypeScript 类型系统与大型项目结构设计方法,并结合 Vite 构建工具优化前端工程化流程。内容包括模块化设计、类型声明管理、代码分割、热更新原理以及构建性能调优。通过完整项目示例,帮助开发者提升代码可维护性与开发效率。

20

2026.02.13

Redis高可用架构与分布式缓存实战
Redis高可用架构与分布式缓存实战

本专题围绕 Redis 在高并发系统中的应用展开,系统讲解主从复制、哨兵机制、Cluster 集群模式及数据分片原理。内容涵盖缓存穿透与雪崩解决方案、分布式锁实现、热点数据优化及持久化策略。通过真实业务场景演示,帮助开发者构建高可用、可扩展的分布式缓存系统。

26

2026.02.13

c语言 数据类型
c语言 数据类型

本专题整合了c语言数据类型相关内容,阅读专题下面的文章了解更多详细内容。

29

2026.02.12

雨课堂网页版登录入口与使用指南_官方在线教学平台访问方法
雨课堂网页版登录入口与使用指南_官方在线教学平台访问方法

本专题系统整理雨课堂网页版官方入口及在线登录方式,涵盖账号登录流程、官方直连入口及平台访问方法说明,帮助师生用户快速进入雨课堂在线教学平台,实现便捷、高效的课程学习与教学管理体验。

14

2026.02.12

豆包AI网页版入口与智能创作指南_官方在线写作与图片生成使用方法
豆包AI网页版入口与智能创作指南_官方在线写作与图片生成使用方法

本专题汇总豆包AI官方网页版入口及在线使用方式,涵盖智能写作工具、图片生成体验入口和官网登录方法,帮助用户快速直达豆包AI平台,高效完成文本创作与AI生图任务,实现便捷智能创作体验。

524

2026.02.12

PostgreSQL性能优化与索引调优实战
PostgreSQL性能优化与索引调优实战

本专题面向后端开发与数据库工程师,深入讲解 PostgreSQL 查询优化原理与索引机制。内容包括执行计划分析、常见索引类型对比、慢查询优化策略、事务隔离级别以及高并发场景下的性能调优技巧。通过实战案例解析,帮助开发者提升数据库响应速度与系统稳定性。

53

2026.02.12

热门下载

更多
网站特效
/
网站源码
/
网站素材
/
前端模板

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
PHP课程
PHP课程

共137课时 | 12万人学习

JavaScript ES5基础线上课程教学
JavaScript ES5基础线上课程教学

共6课时 | 11.2万人学习

PHP新手语法线上课程教学
PHP新手语法线上课程教学

共13课时 | 0.9万人学习

关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送

Copyright 2014-2026 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号