搜索
首页后端开发php教程ecshop代码详解之init.php,ecshopinit.php_PHP教程

ecshop代码详解之init.php,ecshopinit.php

 在includes/init.php目录下

  因为工作原因,需要对ecshop二次开发,顺便记录一下对ecshop源代码的一些分析:

  首先是init.php文件,这个文件在ecshop每个页面都会 调用到,习惯就先分析它:

<br /><?<span>php

</span><span>/*</span><span>*
 * ECSHOP 前台公用文件
</span><span>*/</span>
<span>//</span><span>防止非法调用 defined-判断常量是否已定义,如果没返回false</span>
<span>if</span> (!<span>defined</span>('IN_ECS'<span>))
{
    </span><span>die</span>('Hacking attempt');<span>//</span><span>die-直接终止程序并输出</span>
<span>}
</span><span>//</span><span>报告所有错误</span>
<span>error_reporting</span>(<span>E_ALL</span><span>);
</span><span>//</span><span>如果获取不到本文件</span>
<span>if</span> (<span>__FILE__</span> == ''<span>)
{
    </span><span>die</span>('Fatal error code: 0'<span>);
}
</span><span>/*</span><span>预定义常量
__LINE__       文件中的当前行号。
__FILE__       文件的完整路径和文件名。
__FUNCTION__   函数名称(这是 PHP 4.3.0 新加的)。
__CLASS__      类的名称(这是 PHP 4.3.0 新加的)。
__METHOD__     类的方法名(这是 PHP 5.0.0 新加的)。
</span><span>*/</span>
<span>/*</span><span> 取得当前商城所在的根目录 </span><span>*/</span>
<span>define</span>('ROOT_PATH', <span>str_replace</span>('includes/init.php', '', <span>str_replace</span>('\\', '/', <span>__FILE__</span><span>)));
</span><span>//</span><span>检测是否已安装</span>
<span>if</span> (!<span>file_exists</span>(ROOT_PATH . 'data/install.lock') && !<span>file_exists</span>(ROOT_PATH . 'includes/install.lock'<span>)
    </span>&& !<span>defined</span>('NO_CHECK_INSTALL'<span>))
{
    </span><span>header</span>("Location: ./install/index.php\n"<span>);

    </span><span>exit</span><span>;
}

</span><span>/*</span><span> 初始化设置 </span><span>*/</span><span>
@</span><span>ini_set</span>('memory_limit',          '64M');<span>//</span><span>ini_set设置php.ini中的设置,memory_limit设定一个脚本所能够申请到的最大内存字节数</span>
@<span>ini_set</span>('session.cache_expire',  180);<span>//</span><span>指定会话页面在客户端cache中的有效期限(分钟),单位为分钟。</span>
@<span>ini_set</span>('session.use_trans_sid', 0);<span>//</span><span>关闭自动把session id嵌入到web的URL中</span>
@<span>ini_set</span>('session.use_cookies',   1);<span>//</span><span>允许使用cookie在客户端保存会话ID</span>
@<span>ini_set</span>('session.auto_start',    0);<span>//</span><span>在客户访问任何页面时都自动初始化会话,0-禁止</span>
@<span>ini_set</span>('display_errors',        1);<span>//</span><span>是否显示错误</span>

<span>if</span> (DIRECTORY_SEPARATOR == '\\')<span>//</span><span>如果装在windows上(DIRECTORY_SEPARATOR路径分隔符,linux上就是&rsquo;/&rsquo;   windows上是&rsquo;\&rsquo;)</span>
<span>{
    @</span><span>ini_set</span>('include_path', '.;' . ROOT_PATH);<span>//</span><span>include目录为当前目录和网站根目录,windows下用';'分隔</span>
<span>}
</span><span>else</span><span>
{
    @</span><span>ini_set</span>('include_path', '.:' . ROOT_PATH);<span>//</span><span>include目录为当前目录和网站根目录,linux下用':'分隔</span>
<span>}

</span><span>require</span>(ROOT_PATH . 'data/config.php');<span>//</span><span>包含配置文件(数据库相关)</span>

<span>if</span> (<span>defined</span>('DEBUG_MODE') == <span>false</span>)<span>//</span><span>如果常量DEBUG_MODE没有定义则定义为0,DEBUG_MODE用于设置ecshp的使用模式</span>
<span>{
    </span><span>define</span>('DEBUG_MODE', 0<span>);
}
</span><span>//</span><span>设定用于所有日期时间函数的默认时区</span>
<span>if</span> (<span>PHP_VERSION</span> >= '5.1' && !<span>empty</span>(<span>$timezone</span><span>))
{
    date_default_timezone_set(</span><span>$timezone</span>);<span>//</span><span>date_default_timezone_set 设置时区</span>
<span>}
</span><span>//</span><span>$_SERVER['PHP_SELF']返回当前页面,获取$_SERVER['PHP_SELF']最好用htmlspecialchars过滤一下,存在XSS漏洞</span>
<span>$php_self</span> = <span>isset</span>(<span>$_SERVER</span>['PHP_SELF']) ? <span>$_SERVER</span>['PHP_SELF'] : <span>$_SERVER</span>['SCRIPT_NAME'<span>];
</span><span>if</span> ('/' == <span>substr</span>(<span>$php_self</span>, -1))<span>//</span><span>如果是"/"结尾,则加上index.php</span>
<span>{
    </span><span>$php_self</span> .= 'index.php'<span>;
}
</span><span>define</span>('PHP_SELF', <span>$php_self</span>);<span>//</span><span>放入常量</span>

<span>require</span>(ROOT_PATH . 'includes/inc_constant.php');<span>//</span><span>包含预定义常量文件</span>
<span>require</span>(ROOT_PATH . 'includes/cls_ecshop.php');<span>//</span><span>基础类 文件</span>
<span>require</span>(ROOT_PATH . 'includes/cls_error.php');<span>//</span><span>错误类 文件</span>
<span>require</span>(ROOT_PATH . 'includes/lib_time.php');<span>//</span><span>时间函数</span>
<span>require</span>(ROOT_PATH . 'includes/lib_base.php');<span>//</span><span>基础函数库</span>
<span>require</span>(ROOT_PATH . 'includes/lib_common.php');<span>//</span><span>基础函数库</span>
<span>require</span>(ROOT_PATH . 'includes/lib_main.php');<span>//</span><span>公用函数库</span>
<span>require</span>(ROOT_PATH . 'includes/lib_insert.php');<span>//</span><span>动态内容函数库</span>
<span>require</span>(ROOT_PATH . 'includes/lib_goods.php');<span>//</span><span>商品相关函数库</span>
<span>require</span>(ROOT_PATH . 'includes/lib_article.php');<span>//</span><span>文章及文章分类相关函数库</span>

<span>/*</span><span> 对用户传入的变量进行转义操作。</span><span>*/</span>
<span>if</span> (!<span>get_magic_quotes_gpc</span><span>())
{
    </span><span>if</span> (!<span>empty</span>(<span>$_GET</span><span>))
    {
        </span><span>$_GET</span>  = addslashes_deep(<span>$_GET</span><span>);
    }
    </span><span>if</span> (!<span>empty</span>(<span>$_POST</span><span>))
    {
        </span><span>$_POST</span> = addslashes_deep(<span>$_POST</span><span>);
    }

    </span><span>$_COOKIE</span>   = addslashes_deep(<span>$_COOKIE</span><span>);
    </span><span>$_REQUEST</span>  = addslashes_deep(<span>$_REQUEST</span><span>);
}

</span><span>/*</span><span> 创建 ECSHOP 对象 </span><span>*/</span>
<span>$ecs</span> = <span>new</span> ECS(<span>$db_name</span>, <span>$prefix</span>);<span>//</span><span>参数说明:数据库名 表前缀</span>
<span>define</span>('DATA_DIR', <span>$ecs</span>->data_dir());<span>//</span><span>数据目录</span>
<span>define</span>('IMAGE_DIR', <span>$ecs</span>->image_dir());<span>//</span><span>图片目录</span>

<span>/*</span><span> 初始化数据库类 </span><span>*/</span>
<span>require</span>(ROOT_PATH . 'includes/cls_mysql.php'<span>); 
</span><span>$db</span> = <span>new</span> cls_mysql(<span>$db_host</span>, <span>$db_user</span>, <span>$db_pass</span>, <span>$db_name</span><span>);
</span><span>/*</span><span> 设置不允许进行缓存的表 </span><span>*/</span>
<span>$db</span>->set_disable_cache_tables(<span>array</span>(<span>$ecs</span>->table('sessions'), <span>$ecs</span>->table('sessions_data'), <span>$ecs</span>->table('cart'<span>)));
</span><span>$db_host</span> = <span>$db_user</span> = <span>$db_pass</span> = <span>$db_name</span> = <span>NULL</span><span>;

</span><span>/*</span><span> 创建错误处理对象 </span><span>*/</span>
<span>$err</span> = <span>new</span> ecs_error('message.dwt'<span>);

</span><span>/*</span><span> 载入系统参数 </span><span>*/</span>
<span>$_CFG</span> = load_config(); <span>//</span><span>载入配置信息函数在lib_common.php</span>

<span>/*</span><span> 载入语言文件 </span><span>*/</span>
<span>require</span>(ROOT_PATH . 'languages/' . <span>$_CFG</span>['lang'] . '/common.php'<span>);

</span><span>if</span> (<span>$_CFG</span>['shop_closed'] == 1<span>)
{
    </span><span>/*</span><span> 商店关闭了,输出关闭的消息 </span><span>*/</span>
    <span>header</span>('Content-type: text/html; charset='.<span>EC_CHARSET);

    </span><span>die</span>('<div>$_LANG</span>['shop_closed'] . '</p><p>' . <span>$_CFG</span>['close_comment'] . '</p></div>'<span>);
}

</span><span>//</span><span>判断是否为搜索引擎蜘蛛  函数在lib_main.php</span>
<span>if</span><span> (is_spider())
{
    </span><span>/*</span><span> 如果是蜘蛛的访问,那么默认为访客方式,并且不记录到日志中 </span><span>*/</span>
    <span>if</span> (!<span>defined</span>('INIT_NO_USERS'<span>))
    {
        </span><span>define</span>('INIT_NO_USERS', <span>true</span><span>);
        </span><span>/*</span><span> 整合UC后,如果是蜘蛛访问,初始化UC需要的常量 </span><span>*/</span>
        <span>if</span>(<span>$_CFG</span>['integrate_code'] == 'ucenter'<span>)
        {
             </span><span>$user</span> = &<span> init_users();
        }
    }
    </span><span>$_SESSION</span> = <span>array</span><span>();
    </span><span>$_SESSION</span>['user_id']     = 0<span>;
    </span><span>$_SESSION</span>['user_name']   = ''<span>;
    </span><span>$_SESSION</span>['email']       = ''<span>;
    </span><span>$_SESSION</span>['user_rank']   = 0<span>;
    </span><span>$_SESSION</span>['discount']    = 1.00<span>;
}
</span><span>//</span><span>非搜索引擎蜘蛛,记录session</span>
<span>if</span> (!<span>defined</span>('INIT_NO_USERS'<span>))
{
    </span><span>/*</span><span> 初始化session </span><span>*/</span>
    <span>include</span>(ROOT_PATH . 'includes/cls_session.php'<span>);

    </span><span>$sess</span> = <span>new</span> cls_session(<span>$db</span>, <span>$ecs</span>->table('sessions'), <span>$ecs</span>->table('sessions_data'<span>));

    </span><span>define</span>('SESS_ID', <span>$sess</span>-><span>get_session_id());
}
</span><span>//</span><span>如果使用Smarty</span>
<span>if</span> (!<span>defined</span>('INIT_NO_SMARTY'<span>))
{
    </span><span>header</span>('Cache-control: private'<span>);
    </span><span>header</span>('Content-type: text/html; charset='.<span>EC_CHARSET);

    </span><span>/*</span><span> 创建 Smarty 对象。</span><span>*/</span>
    <span>require</span>(ROOT_PATH . 'includes/cls_template.php'<span>);
    </span><span>$smarty</span> = <span>new</span><span> cls_template;

    </span><span>$smarty</span>->cache_lifetime = <span>$_CFG</span>['cache_time'];<span>//</span><span>缓存时间</span>
    <span>$smarty</span>->template_dir   = ROOT_PATH . 'themes/' . <span>$_CFG</span>['template'];<span>//</span><span>模板所在</span>
    <span>$smarty</span>->cache_dir      = ROOT_PATH . 'temp/caches';<span>//</span><span>缓存所在</span>
    <span>$smarty</span>->compile_dir    = ROOT_PATH . 'temp/compiled';<span>//</span><span>模板编译后的文件所在</span>

    <span>if</span> ((DEBUG_MODE & 2) == 2)<span>//</span><span>如果常量DEBUG_MODE值为 2、3、6、7.时</span>
<span>    {
        </span><span>$smarty</span>->direct_output = <span>true</span>; <span>//</span><span>不使用缓存直接输出</span>
        <span>$smarty</span>->force_compile = <span>true</span>; <span>//</span><span>强行编译</span>
<span>    }
    </span><span>else</span><span>
    {
        </span><span>$smarty</span>->direct_output = <span>false</span><span>;
        </span><span>$smarty</span>->force_compile = <span>false</span><span>;
    }

    </span><span>$smarty</span>->assign('lang', <span>$_LANG</span><span>);
    </span><span>$smarty</span>->assign('ecs_charset',<span> EC_CHARSET);
    </span><span>if</span> (!<span>empty</span>(<span>$_CFG</span>['stylename']))<span>//</span><span>如果自己定义样式文件就用自己的</span>
<span>    {
        </span><span>$smarty</span>->assign('ecs_css_path', 'themes/' . <span>$_CFG</span>['template'] . '/style_' . <span>$_CFG</span>['stylename'] . '.css'<span>);
    }
    </span><span>else</span><span>
    {
        </span><span>$smarty</span>->assign('ecs_css_path', 'themes/' . <span>$_CFG</span>['template'] . '/style.css'<span>);
    }

}
</span><span>//</span><span>非搜索引擎爬虫,记录用户信息</span>
<span>if</span> (!<span>defined</span>('INIT_NO_USERS'<span>))
{
    </span><span>/*</span><span> 会员信息  初始化会员数据 lib_common.php </span><span>*/</span> 
    <span>$user</span> =&<span> init_users();

    </span><span>if</span> (!<span>isset</span>(<span>$_SESSION</span>['user_id'<span>]))
    {
        </span><span>/*</span><span> 获取投放站点的名称 </span><span>*/</span>
        <span>$site_name</span> = <span>isset</span>(<span>$_GET</span>['from'])   ? <span>$_GET</span>['from'] : <span>addslashes</span>(<span>$_LANG</span>['self_site'<span>]);
        </span><span>$from_ad</span>   = !<span>empty</span>(<span>$_GET</span>['ad_id']) ? <span>intval</span>(<span>$_GET</span>['ad_id']) : 0<span>;

        </span><span>$_SESSION</span>['from_ad'] = <span>$from_ad</span>; <span>//</span><span> 用户点击的广告ID</span>
        <span>$_SESSION</span>['referer'] = <span>stripslashes</span>(<span>$site_name</span>); <span>//</span><span> 用户来源</span>

        <span>unset</span>(<span>$site_name</span><span>);

        </span><span>if</span> (!<span>defined</span>('INGORE_VISIT_STATS'<span>))
        {
            visit_stats();
        }
    }

    </span><span>if</span> (<span>empty</span>(<span>$_SESSION</span>['user_id'<span>]))
    {
        </span><span>if</span> (<span>$user</span>-><span>get_cookie())
        {
            </span><span>/*</span><span> 如果会员已经登录并且还没有获得会员的帐户余额、积分以及优惠券 </span><span>*/</span>
            <span>if</span> (<span>$_SESSION</span>['user_id'] > 0<span>)
            {
                update_user_info();
            }
        }
        </span><span>else</span><span>
        {
            </span><span>$_SESSION</span>['user_id']     = 0<span>;
            </span><span>$_SESSION</span>['user_name']   = ''<span>;
            </span><span>$_SESSION</span>['email']       = ''<span>;
            </span><span>$_SESSION</span>['user_rank']   = 0<span>;
            </span><span>$_SESSION</span>['discount']    = 1.00<span>;
            </span><span>if</span> (!<span>isset</span>(<span>$_SESSION</span>['login_fail'<span>]))
            {
                </span><span>$_SESSION</span>['login_fail'] = 0<span>;
            }
        }
    }

    </span><span>/*</span><span> 设置推荐会员 </span><span>*/</span>
    <span>if</span> (<span>isset</span>(<span>$_GET</span>['u'<span>]))
    {
        set_affiliate();
    }
    </span><span>if</span> (<span>isset</span>(<span>$smarty</span><span>))
    {
        </span><span>$smarty</span>->assign('ecs_session', <span>$_SESSION</span><span>);
    }
}

</span><span>if</span> ((DEBUG_MODE & 1) == 1)<span>//</span><span>如果常量DEBUG_MODE值为 1、3、5、7.时</span>
<span>{
    </span><span>error_reporting</span>(<span>E_ALL</span>);<span>//</span><span>报告全部错误</span>
<span>}
</span><span>else</span><span>
{
    </span><span>error_reporting</span>(<span>E_ALL</span> ^ <span>E_NOTICE</span>); <span>//</span><span>报告除E_NOTICE以外的所有错误</span>
<span>}
</span><span>if</span> ((DEBUG_MODE & 4) == 4)<span>//</span><span>如果常量DEBUG_MODE值为 4、5、6、7.时,调试程序</span>
<span>{
    </span><span>include</span>(ROOT_PATH . 'includes/lib.debug.php');<span>//
</span><span>}

</span><span>/*</span><span> 判断是否支持 Gzip 模式  如果使用SMARTY同时设置了网页压缩,则启用压缩 </span><span>*/</span>
<span>if</span> (!<span>defined</span>('INIT_NO_SMARTY') &&<span> gzip_enabled())
{
    </span><span>ob_start</span>('ob_gzhandler');<span>//</span><span>压缩后放入缓冲区</span>
<span>}
</span><span>else</span><span>
{
    </span><span>ob_start</span>();<span>//</span><span>打开缓冲区,把下面要显示的内容先缓在服务器</span>
<span>}
</span><span>/*</span><span>
ob_start相关函数了解:
1、Flush:刷新缓冲区的内容,输出。
函数格式:flush()
说明:这个函数经常使用,效率很高。
2、ob_start :打开输出缓冲区
函数格式:void ob_start(void)
说明:当缓冲区激活时,所有来自PHP程序的非文件头信息均不会发送,而是保存在内部缓冲区。为了输出缓冲区的内容,可以使用ob_end_flush()或flush()输出缓冲区的内容。
、ob_get_contents :返回内部缓冲区的内容。
使用方法:string ob_get_contents(void)
说明:这个函数会返回当前缓冲区中的内容,如果输出缓冲区没有激活,则返回 FALSE 。
4、ob_get_length:返回内部缓冲区的长度。
使用方法:int ob_get_length(void)
说明:这个函数会返回当前缓冲区中的长度;和ob_get_contents一样,如果输出缓冲区没有激活。则返回 FALSE。
5、ob_end_flush :发送内部缓冲区的内容到浏览器,并且关闭输出缓冲区。
使用方法:void ob_end_flush(void)
说明:这个函数发送输出缓冲区的内容(如果有的话)。
6、ob_end_clean:删除内部缓冲区的内容,并且关闭内部缓冲区
使用方法:void ob_end_clean(void)
说明:这个函数不会输出内部缓冲区的内容而是把它删除!
7、ob_implicit_flush:打开或关闭绝对刷新
使用方法:void ob_implicit_flush ([int flag])
说明:使用过Perl的人都知道$|=x的意义,这个字符串可以打开/关闭缓冲区,而ob_implicit_flush函数也和那个一样,默认为关闭缓冲区,打开绝对输出后,每个脚本输出都直接发送到浏览器,不再需要调用 flush()
</span><span>*/</span>
?>

 

www.bkjia.comtruehttp://www.bkjia.com/PHPjc/910352.htmlTechArticleecshop代码详解之init.php,ecshopinit.php 在includes/init.php目录下 因为工作原因,需要对ecshop二次开发,顺便记录一下对ecshop源代码的一些分析:...
声明
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn
PHP电子邮件:分步发送指南PHP电子邮件:分步发送指南May 09, 2025 am 12:14 AM

phpisusedforsendendemailsduetoitsignegrationwithservermailservicesand andexternalsmtpproviders,自动化notifications andMarketingCampaigns.1)设置设置yourphpenvironcormentswironmentswithaweberswithawebserverserverserverandphp,确保themailfunctionisenabled.2)useabasicscruct

如何通过PHP发送电子邮件:示例和代码如何通过PHP发送电子邮件:示例和代码May 09, 2025 am 12:13 AM

发送电子邮件的最佳方法是使用PHPMailer库。1)使用mail()函数简单但不可靠,可能导致邮件进入垃圾邮件或无法送达。2)PHPMailer提供更好的控制和可靠性,支持HTML邮件、附件和SMTP认证。3)确保正确配置SMTP设置并使用加密(如STARTTLS或SSL/TLS)以增强安全性。4)对于大量邮件,考虑使用邮件队列系统来优化性能。

高级PHP电子邮件:自定义标题和功能高级PHP电子邮件:自定义标题和功能May 09, 2025 am 12:13 AM

CustomHeadersheadersandAdvancedFeaturesInphpeMailenHanceFunctionalityAndreliability.1)CustomHeadersheadersheadersaddmetadatatatatataatafortrackingandCategorization.2)htmlemailsallowformattingandttinganditive.3)attachmentscanmentscanmentscanbesmentscanbestmentscanbesentscanbesentingslibrarieslibrarieslibrariesliblarikelikephpmailer.4)smtppapapairatienticationaltication enterticationallimpr

使用PHP和SMTP发送电子邮件的指南使用PHP和SMTP发送电子邮件的指南May 09, 2025 am 12:06 AM

使用PHP和SMTP发送邮件可以通过PHPMailer库实现。1)安装并配置PHPMailer,2)设置SMTP服务器细节,3)定义邮件内容,4)发送邮件并处理错误。使用此方法可以确保邮件的可靠性和安全性。

使用PHP发送电子邮件的最佳方法是什么?使用PHP发送电子邮件的最佳方法是什么?May 08, 2025 am 12:21 AM

ThebestapproachforsendingemailsinPHPisusingthePHPMailerlibraryduetoitsreliability,featurerichness,andeaseofuse.PHPMailersupportsSMTP,providesdetailederrorhandling,allowssendingHTMLandplaintextemails,supportsattachments,andenhancessecurity.Foroptimalu

PHP中依赖注入的最佳实践PHP中依赖注入的最佳实践May 08, 2025 am 12:21 AM

使用依赖注入(DI)的原因是它促进了代码的松耦合、可测试性和可维护性。1)使用构造函数注入依赖,2)避免使用服务定位器,3)利用依赖注入容器管理依赖,4)通过注入依赖提高测试性,5)避免过度注入依赖,6)考虑DI对性能的影响。

PHP性能调整技巧和技巧PHP性能调整技巧和技巧May 08, 2025 am 12:20 AM

phperformancetuningiscialbecapeitenhancesspeedandeffice,whatevitalforwebapplications.1)cachingwithapcureduccureducesdatabaseloadprovesrovesponsemetimes.2)优化

PHP电子邮件安全性:发送电子邮件的最佳实践PHP电子邮件安全性:发送电子邮件的最佳实践May 08, 2025 am 12:16 AM

ThebestpracticesforsendingemailssecurelyinPHPinclude:1)UsingsecureconfigurationswithSMTPandSTARTTLSencryption,2)Validatingandsanitizinginputstopreventinjectionattacks,3)EncryptingsensitivedatawithinemailsusingOpenSSL,4)Properlyhandlingemailheaderstoa

See all articles

热AI工具

Undresser.AI Undress

Undresser.AI Undress

人工智能驱动的应用程序,用于创建逼真的裸体照片

AI Clothes Remover

AI Clothes Remover

用于从照片中去除衣服的在线人工智能工具。

Undress AI Tool

Undress AI Tool

免费脱衣服图片

Clothoff.io

Clothoff.io

AI脱衣机

Video Face Swap

Video Face Swap

使用我们完全免费的人工智能换脸工具轻松在任何视频中换脸!

热工具

SublimeText3 英文版

SublimeText3 英文版

推荐:为Win版本,支持代码提示!

SublimeText3 Linux新版

SublimeText3 Linux新版

SublimeText3 Linux最新版

适用于 Eclipse 的 SAP NetWeaver 服务器适配器

适用于 Eclipse 的 SAP NetWeaver 服务器适配器

将Eclipse与SAP NetWeaver应用服务器集成。

SublimeText3 Mac版

SublimeText3 Mac版

神级代码编辑软件(SublimeText3)

安全考试浏览器

安全考试浏览器

Safe Exam Browser是一个安全的浏览器环境,用于安全地进行在线考试。该软件将任何计算机变成一个安全的工作站。它控制对任何实用工具的访问,并防止学生使用未经授权的资源。