You can not select more than 25 topics
Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
716 lines
27 KiB
716 lines
27 KiB
11 months ago
|
<?php
|
||
|
// +----------------------------------------------------------------------
|
||
|
// | 天诚科技 [ 刘海东 17600099397赋能开发者,助力企业发展 ]
|
||
|
// +----------------------------------------------------------------------
|
||
|
// | Copyright (c) 2016~2020 https://www.tczxkj.com All rights reserved.
|
||
|
// +----------------------------------------------------------------------
|
||
|
// | Licensed 该系统并不是自由软件,未经许可不能去掉相关版权
|
||
|
// +----------------------------------------------------------------------
|
||
|
// | Author:甘肃天诚志信电子商务有限公司 刘海东 联系电话维系17600099397
|
||
|
// +----------------------------------------------------------------------
|
||
|
|
||
|
namespace app\wap\controller;
|
||
|
|
||
|
use service\GroupDataService;
|
||
|
use service\SystemConfigService;
|
||
|
use think\Cache;
|
||
|
use think\Request;
|
||
|
use think\Url;
|
||
|
use service\JsonService;
|
||
|
use service\UtilService;
|
||
|
use app\wap\model\topic\TestPaperCategory;
|
||
|
use app\wap\model\topic\TestPaper;
|
||
|
use app\wap\model\topic\TestPaperQuestions;
|
||
|
use app\wap\model\special\Special as SpecialModel;
|
||
|
use app\wap\model\topic\Questions;
|
||
|
use app\wap\model\topic\ExaminationRecord;
|
||
|
use app\wap\model\topic\ExaminationTestRecord;
|
||
|
use app\wap\model\topic\ExaminationWrongBank;
|
||
|
use app\wap\model\topic\TestPaperObtain;
|
||
|
use app\wap\model\topic\CertificateRecord;
|
||
|
use app\wap\model\topic\CertificateRelated;
|
||
|
use app\wap\model\topic\Relation;
|
||
|
use app\wap\model\merchant\Merchant as MerchantModel;
|
||
|
|
||
|
/**题库控制器
|
||
|
* Class Topic
|
||
|
* @package app\wap\controller
|
||
|
*/
|
||
|
class Topic extends AuthController
|
||
|
{
|
||
|
/**
|
||
|
* 白名单
|
||
|
* */
|
||
|
public static function WhiteList()
|
||
|
{
|
||
|
return [
|
||
|
'question_category',
|
||
|
'testPaperCate',
|
||
|
'practiceList',
|
||
|
'problem_index',
|
||
|
'specialTestPaper',
|
||
|
'testPaperDetails',
|
||
|
'situationRecord',
|
||
|
'userAnswer',
|
||
|
'takeTheTestAgain',
|
||
|
'continueAnswer'
|
||
|
];
|
||
|
}
|
||
|
|
||
|
/**练习详情
|
||
|
* @return mixed
|
||
|
*/
|
||
|
public function problem_index($id = 0)
|
||
|
{
|
||
|
if (!$id) $this->failed('缺少参数,无法访问', Url::build('index/index'));
|
||
|
$title = TestPaper::PreExercisesWhere()->where('id', $id)->value('title');
|
||
|
$this->assign(['uid' => $this->uid, 'titles' => $title, 'id' => $id]);
|
||
|
return $this->fetch();
|
||
|
}
|
||
|
|
||
|
/**练习答题
|
||
|
* @return mixed
|
||
|
*/
|
||
|
public function problem_detail($test_id)
|
||
|
{
|
||
|
if (!$test_id) $this->failed('缺少参数,无法访问', Url::build('index/index'));
|
||
|
$title = TestPaper::PreExercisesWhere()->where('id', $test_id)->value('title');
|
||
|
$isPay = (!$this->uid || $this->uid == 0) ? false : TestPaperObtain::PayTestPaper($test_id, $this->uid, 1);
|
||
|
if (!$isPay) $this->failed('您暂未获得练习试题', Url::build('topic/problem_index', ['id' => $test_id]));
|
||
|
$this->assign(['uid' => $this->uid, 'titles' => $title]);
|
||
|
return $this->fetch();
|
||
|
}
|
||
|
|
||
|
/**练习答题卡
|
||
|
* @return mixed
|
||
|
*/
|
||
|
public function problem_sheet()
|
||
|
{
|
||
|
return $this->fetch();
|
||
|
}
|
||
|
|
||
|
/**考试答题
|
||
|
* @return mixed
|
||
|
*/
|
||
|
public function question_detail($test_id)
|
||
|
{
|
||
|
if (!$test_id) $this->failed('缺少参数,无法访问', Url::build('index/index'));
|
||
|
$test = TestPaper::PreExercisesWhere()->where('id', $test_id)->field('title,txamination_time')->find();
|
||
|
$isPay = (!$this->uid || $this->uid == 0) ? false : TestPaperObtain::PayTestPaper($test_id, $this->uid, 2);
|
||
|
if (!$isPay) $this->failed('您还未购买考试试卷', Url::build('special/question_index', ['id' => $test_id]));
|
||
|
$this->assign(['uid' => $this->uid, 'titles' => $test['title'], 'txamination_time' => $test['txamination_time']]);
|
||
|
return $this->fetch();
|
||
|
}
|
||
|
|
||
|
public function question_detail_api($test_id)
|
||
|
{
|
||
|
if (!$test_id) return JsonService::fail('缺少参数,无法访问');
|
||
|
$test = TestPaper::PreExercisesWhere()->where('id', $test_id)->field('title,txamination_time')->find();
|
||
|
$isPay = (!$this->uid || $this->uid == 0) ? false : TestPaperObtain::PayTestPaper($test_id, $this->uid, 2);
|
||
|
if (!$isPay)return JsonService::fail('您还未购买考试试卷');
|
||
|
return JsonService::successful([
|
||
|
'uid' => $this->uid, 'titles' => $test['title'], 'txamination_time' => $test['txamination_time']
|
||
|
]);
|
||
|
}
|
||
|
|
||
|
/**考试答题卡
|
||
|
* @return mixed
|
||
|
*/
|
||
|
public function question_sheet()
|
||
|
{
|
||
|
return $this->fetch();
|
||
|
}
|
||
|
|
||
|
/**考试评测
|
||
|
* @return mixed
|
||
|
*/
|
||
|
public function question_user()
|
||
|
{
|
||
|
return $this->fetch();
|
||
|
}
|
||
|
|
||
|
/**我的错题
|
||
|
* @return mixed
|
||
|
*/
|
||
|
public function question_wrong()
|
||
|
{
|
||
|
return $this->fetch();
|
||
|
}
|
||
|
|
||
|
/**
|
||
|
* 练习、考试分类
|
||
|
*/
|
||
|
public function question_category($type = 1)
|
||
|
{
|
||
|
$this->assign([
|
||
|
'homeLogo' => SystemConfigService::get('home_logo'),
|
||
|
'type' => $type
|
||
|
]);
|
||
|
return $this->fetch();
|
||
|
}
|
||
|
|
||
|
/**
|
||
|
* 我的证书
|
||
|
*/
|
||
|
public function certificate_list()
|
||
|
{
|
||
|
return $this->fetch();
|
||
|
}
|
||
|
|
||
|
/**
|
||
|
* 荣誉证书
|
||
|
*/
|
||
|
public function certificate_detail()
|
||
|
{
|
||
|
return $this->fetch();
|
||
|
}
|
||
|
|
||
|
/**
|
||
|
* 考试结果
|
||
|
*/
|
||
|
public function question_result()
|
||
|
{
|
||
|
return $this->fetch();
|
||
|
}
|
||
|
|
||
|
/**
|
||
|
* 练习结果
|
||
|
*/
|
||
|
public function problem_result()
|
||
|
{
|
||
|
return $this->fetch();
|
||
|
}
|
||
|
|
||
|
/**
|
||
|
* 错题详情
|
||
|
*/
|
||
|
public function question_detail_wrong()
|
||
|
{
|
||
|
return $this->fetch();
|
||
|
}
|
||
|
|
||
|
/**
|
||
|
* 试卷分类
|
||
|
* @param int $type 1=练习 2=考试
|
||
|
*/
|
||
|
public function testPaperCate($type = 1)
|
||
|
{
|
||
|
$cateogry = TestPaperCategory::with('children')->where(['is_show' => 1, 'is_del' => 0, 'type' => $type])->order('sort desc,id desc')->where('pid', 0)->select();
|
||
|
return JsonService::successful($cateogry->toArray());
|
||
|
}
|
||
|
|
||
|
/**
|
||
|
* 试卷列表
|
||
|
*/
|
||
|
public function practiceList($type = 1)
|
||
|
{
|
||
|
list($page, $limit, $pid, $tid, $search) = UtilService::PostMore([
|
||
|
['page', 1],
|
||
|
['limit', 10],
|
||
|
['pid', 0],
|
||
|
['tid', 0],
|
||
|
['search', ''],
|
||
|
], $this->request, true);
|
||
|
return JsonService::successful(TestPaper::getTestPaperExercisesList($type, $page, $limit, $pid, $tid, $search));
|
||
|
}
|
||
|
|
||
|
/**试卷详情
|
||
|
* @param int $id
|
||
|
*/
|
||
|
public function testPaperDetails($id = 0)
|
||
|
{
|
||
|
if (!$id) return JsonService::fail('缺少参数,无法访问');
|
||
|
$testPaper = TestPaper::PreExercisesWhere()->where('id', $id)->find();
|
||
|
if (!$testPaper) return JsonService::fail('试卷不存在');
|
||
|
$isPay = 0;
|
||
|
$surplus = -1; //剩余考试次数 -1 无限次 0 无法答题
|
||
|
if ($this->uid) {
|
||
|
if ($testPaper['type'] == 1) {
|
||
|
$isPay = 1;
|
||
|
if (!TestPaperObtain::PayTestPaper($id, $this->uid, 1)) {
|
||
|
TestPaperObtain::setUserTestPaper('', $id, $this->uid, 1, 2);
|
||
|
}
|
||
|
} else if ($testPaper['type'] == 2) {
|
||
|
if (in_array($testPaper['money'], [0, 0.00]) || in_array($testPaper['pay_type'], [PAY_NO_MONEY])) {
|
||
|
$res = true;
|
||
|
if (!TestPaperObtain::PayTestPaper($id, $this->uid, 2)) {
|
||
|
$res = TestPaperObtain::setUserTestPaper('', $id, $this->uid, 2, 2);
|
||
|
}
|
||
|
if ($res) $isPay = 1;
|
||
|
} else {
|
||
|
$business = isset($this->userInfo['business']) ? $this->userInfo['business'] : 0;
|
||
|
$isPay = TestPaperObtain::PayTestPaper($id, $this->uid, 2);
|
||
|
if (!$isPay && $business) {
|
||
|
$mer_id = MerchantModel::getMerId($this->uid);
|
||
|
$res = false;
|
||
|
if ($mer_id == $testPaper['mer_id']) {
|
||
|
$res = TestPaperObtain::setUserTestPaper('', $id, $this->uid, 2, 2);
|
||
|
}
|
||
|
if ($res) $isPay = 1;
|
||
|
}
|
||
|
}
|
||
|
$surplus = $testPaper['frequency'] == 0 ? -1 : $testPaper['frequency'];
|
||
|
if ($isPay && $testPaper['frequency'] > 0) {
|
||
|
$number = TestPaperObtain::where(['uid' => $this->uid, 'test_id' => $id, 'type' => 2, 'is_del' => 0])->value('number');
|
||
|
$surplus = bcsub($testPaper['frequency'], $number, 0);
|
||
|
}
|
||
|
}
|
||
|
}
|
||
|
$testPaper['surplus'] = $surplus;
|
||
|
$testPaper['isPay'] = $isPay;
|
||
|
$testPaper['answer'] = $testPaper['answer'] + $testPaper['fake_sales'] ;
|
||
|
return JsonService::successful($testPaper);
|
||
|
}
|
||
|
|
||
|
/**检查试卷答题情况
|
||
|
* @param $id
|
||
|
* @throws \think\Exception
|
||
|
* @throws \think\db\exception\DataNotFoundException
|
||
|
* @throws \think\db\exception\ModelNotFoundException
|
||
|
* @throws \think\exception\DbException
|
||
|
*/
|
||
|
public function situationRecord($id)
|
||
|
{
|
||
|
if (!$id) return JsonService::fail('缺少参数,无法访问');
|
||
|
$testPaper = TestPaper::PreExercisesWhere()->where('id', $id)->find();
|
||
|
if (!$testPaper) return JsonService::fail('试卷不存在');
|
||
|
$record = 0;
|
||
|
if (!$this->uid) return JsonService::successful('ok', $record);
|
||
|
$count = ExaminationRecord::where(['test_id' => $testPaper['id'], 'type' => $testPaper['type'], 'uid' => $this->uid])->count();
|
||
|
if ($count) {
|
||
|
$userRecord = ExaminationRecord::where(['test_id' => $testPaper['id'], 'type' => $testPaper['type'], 'uid' => $this->uid, 'is_submit' => 0])->order('id desc')->find();
|
||
|
if ($userRecord) {
|
||
|
$record = 2;//继续答题
|
||
|
if ($testPaper['type'] == 2) {
|
||
|
if (bcsub($userRecord['end_time'], time(), 0) <= 0) {
|
||
|
$data = [
|
||
|
'examination_id' => $userRecord['id'],
|
||
|
'type' => $testPaper['type'],
|
||
|
'duration' => $testPaper['txamination_time'],
|
||
|
'score' => 0
|
||
|
];
|
||
|
$res = ExaminationRecord::submitExaminationRecord($data, $this->uid);
|
||
|
if (!$res) {
|
||
|
ExaminationRecord::clearLastExamResults($id, $testPaper['type'], $this->uid);
|
||
|
}
|
||
|
$record = 1;
|
||
|
}
|
||
|
}
|
||
|
} else {
|
||
|
$record = 1;//再次答题
|
||
|
}
|
||
|
} else {
|
||
|
$record = 0; //没有答过题
|
||
|
}
|
||
|
return JsonService::successful('ok', $record);
|
||
|
}
|
||
|
|
||
|
/**用户开始答题
|
||
|
* @param int $id
|
||
|
*/
|
||
|
public function userAnswer($test_id = 0, $type = 1)
|
||
|
{
|
||
|
if (!$test_id) return JsonService::fail('缺少参数,无法访问');
|
||
|
$testPaper = TestPaper::PreExercisesWhere()->where('id', $test_id)->find();
|
||
|
if (!$testPaper) return JsonService::fail('试卷不存在');
|
||
|
$uid = $this->uid;
|
||
|
if ($type == 2 && $uid && $testPaper['type'] == 2) {
|
||
|
$number = TestPaperObtain::where(['uid' => $uid, 'test_id' => $test_id, 'type' => 2, 'is_del' => 0])->value('number');
|
||
|
if ($number >= $testPaper['frequency'] && $testPaper['frequency'] > 0) return JsonService::fail('您的考试次数已用完');
|
||
|
}
|
||
|
$examination_id = ExaminationRecord::addExaminationRecord($test_id, $type, $uid, $testPaper['txamination_time']);
|
||
|
if ($examination_id) {
|
||
|
return JsonService::successful('ok', $examination_id);
|
||
|
} else {
|
||
|
return JsonService::fail('开始答题失败');
|
||
|
}
|
||
|
}
|
||
|
|
||
|
/**再考一次
|
||
|
* @param int $test_id
|
||
|
* @param int $type
|
||
|
* @throws \think\db\exception\DataNotFoundException
|
||
|
* @throws \think\db\exception\ModelNotFoundException
|
||
|
* @throws \think\exception\DbException
|
||
|
*/
|
||
|
public function takeTheTestAgain($test_id = 0, $type = 1)
|
||
|
{
|
||
|
if (!$test_id) return JsonService::fail('缺少参数,无法访问');
|
||
|
$testPaper = TestPaper::PreExercisesWhere()->where('id', $test_id)->find();
|
||
|
if (!$testPaper) return JsonService::fail('试卷不存在');
|
||
|
$uid = $this->uid;
|
||
|
if ($type == 2 && $uid && $testPaper['type'] == 2) {
|
||
|
$number = TestPaperObtain::where(['uid' => $uid, 'test_id' => $test_id, 'type' => 2, 'is_del' => 0])->value('number');
|
||
|
if ($number >= $testPaper['frequency'] && $testPaper['frequency'] > 0) return JsonService::fail('您的考试次数已用完');
|
||
|
}
|
||
|
$examination_id = ExaminationRecord::addExaminationRecord($test_id, $type, $uid, $testPaper['txamination_time']);
|
||
|
if ($examination_id) {
|
||
|
$res = ExaminationRecord::clearLastExamResults($test_id, $type, $uid);
|
||
|
if (!$res) {
|
||
|
return JsonService::fail('再次答题失败');
|
||
|
} else {
|
||
|
return JsonService::successful('ok', $examination_id);
|
||
|
}
|
||
|
} else {
|
||
|
return JsonService::fail('再次答题失败');
|
||
|
}
|
||
|
}
|
||
|
|
||
|
/**继续答题
|
||
|
* @param int $test_id
|
||
|
* @param int $type
|
||
|
* @throws \think\db\exception\DataNotFoundException
|
||
|
* @throws \think\db\exception\ModelNotFoundException
|
||
|
* @throws \think\exception\DbException
|
||
|
*/
|
||
|
public function continueAnswer($test_id = 0, $type = 1)
|
||
|
{
|
||
|
if (!$test_id) return JsonService::fail('缺少参数,无法访问');
|
||
|
$testPaper = TestPaper::PreExercisesWhere()->where('id', $test_id)->find();
|
||
|
if (!$testPaper) return JsonService::fail('试卷不存在');
|
||
|
$record = ExaminationRecord::where(['test_id' => $test_id, 'type' => $type, 'uid' => $this->uid, 'is_submit' => 0])->order('id desc')->find();
|
||
|
if ($record) {
|
||
|
return JsonService::successful('ok', $record['id']);
|
||
|
} else {
|
||
|
return JsonService::fail('继续答题失败');
|
||
|
}
|
||
|
}
|
||
|
|
||
|
/**获取试卷中的试题
|
||
|
* @param $test_id 试卷ID
|
||
|
* @param $type
|
||
|
* @param $record_id 继续答题传入
|
||
|
* @param is_correct 0=未答 1=答错 2=正确
|
||
|
*/
|
||
|
public function testPaperQuestions($test_id, $type, $record_id = 0)
|
||
|
{
|
||
|
if (!$test_id) return JsonService::fail('缺少参数,无法访问');
|
||
|
$testPaper = TestPaper::PreExercisesWhere()->where('id', $test_id)->find();
|
||
|
if (!$testPaper) return JsonService::fail('试卷不存在');
|
||
|
$arr = ['1' => $testPaper['single_sort'], '2' => $testPaper['many_sort'], '3' => $testPaper['judge_sort']];
|
||
|
arsort($arr);
|
||
|
$question = [];
|
||
|
foreach ($arr as $key => $item) {
|
||
|
$single = TestPaperQuestions::getQuestionslist($test_id, $type, $key);
|
||
|
$question = array_merge($question, $single);
|
||
|
}
|
||
|
if (count($question) <= 0) return JsonService::fail('试卷中试题为空');
|
||
|
if ($record_id) {
|
||
|
$record = ExaminationRecord::where(['id' => $record_id, 'test_id' => $test_id, 'type' => $type, 'uid' => $this->uid])->order('id desc')->find();
|
||
|
} else {
|
||
|
$record = false;
|
||
|
}
|
||
|
foreach ($question as $key => &$value) {
|
||
|
if ($record) {
|
||
|
$value['userAnswer'] = ExaminationTestRecord::checkWhetherAnswerQuestions($record['id'], $type, $this->uid, $value['questions_id']);
|
||
|
} else {
|
||
|
$value['userAnswer'] = [];
|
||
|
}
|
||
|
$value['option'] = json_decode($value['option']);
|
||
|
$value['special'] = Relation::getRelationSpecial(3, $value['questions_id']);
|
||
|
}
|
||
|
return JsonService::successful($question);
|
||
|
}
|
||
|
|
||
|
/**答题卡
|
||
|
* @param $test_id 试卷ID
|
||
|
* @param $type
|
||
|
* @param int $record_id 答题记录ID
|
||
|
*/
|
||
|
public function answerSheet($test_id, $type, $record_id = 0)
|
||
|
{
|
||
|
if (!$test_id || !$record_id) return JsonService::fail('缺少参数,无法访问');
|
||
|
$testPaper = TestPaper::PreExercisesWhere()->where('id', $test_id)->find();
|
||
|
if (!$testPaper) return JsonService::fail('试卷不存在');
|
||
|
$arr = ['1' => $testPaper['single_sort'], '2' => $testPaper['many_sort'], '3' => $testPaper['judge_sort']];
|
||
|
arsort($arr);
|
||
|
$testPaperQuestion = [];
|
||
|
foreach ($arr as $key => $item) {
|
||
|
$single = TestPaperQuestions::getQuestionslist($test_id, $type, $key);
|
||
|
$testPaperQuestion = array_merge($testPaperQuestion, $single);
|
||
|
}
|
||
|
$record = ExaminationRecord::where(['id' => $record_id, 'test_id' => $test_id, 'type' => $type, 'uid' => $this->uid])->order('id desc')->find();
|
||
|
if (!$record) return JsonService::fail('考试记录不存在');
|
||
|
foreach ($testPaperQuestion as $key => &$value) {
|
||
|
$value['userAnswer'] = ExaminationTestRecord::checkWhetherAnswerQuestions($record['id'], $type, $this->uid, $value['questions_id']);
|
||
|
}
|
||
|
return JsonService::successful($testPaperQuestion);
|
||
|
}
|
||
|
|
||
|
/**考试结果
|
||
|
* @param $test_id
|
||
|
* @param $type
|
||
|
*/
|
||
|
public function examinationResults($test_id, $type)
|
||
|
{
|
||
|
if (!$test_id) return JsonService::fail('缺少参数,无法访问');
|
||
|
$testPaper = TestPaper::PreExercisesWhere()->where('id', $test_id)->find();
|
||
|
if (!$testPaper) return JsonService::fail('试卷不存在');
|
||
|
$arr = ['1' => $testPaper['single_sort'], '2' => $testPaper['many_sort'], '3' => $testPaper['judge_sort']];
|
||
|
arsort($arr);
|
||
|
$testPaperQuestion = [];
|
||
|
foreach ($arr as $key => $item) {
|
||
|
$single = TestPaperQuestions::getQuestionslist($test_id, $type, $key);
|
||
|
$testPaperQuestion = array_merge($testPaperQuestion, $single);
|
||
|
}
|
||
|
$record = ExaminationRecord::where(['test_id' => $test_id, 'type' => $type, 'uid' => $this->uid, 'is_submit' => 1])->order('id desc')->find();
|
||
|
if (!$record) return JsonService::fail('考试记录不存在');
|
||
|
foreach ($testPaperQuestion as $key => &$value) {
|
||
|
$value['userAnswer'] = ExaminationTestRecord::checkWhetherAnswerQuestions($record['id'], $type, $this->uid, $value['questions_id']);
|
||
|
}
|
||
|
$record['title'] = $testPaper['title'];
|
||
|
$record['is_score'] = $testPaper['is_score'];
|
||
|
$record['test_paper_question'] = $testPaperQuestion;
|
||
|
$record['not_questions'] = bcsub($testPaper['item_number'], bcadd($record['yes_questions'], $record['wrong_question'], 0), 0);
|
||
|
return JsonService::successful($record);
|
||
|
}
|
||
|
|
||
|
/**保存试题答题结果
|
||
|
* @param int $id
|
||
|
*/
|
||
|
public function submitQuestions()
|
||
|
{
|
||
|
$data = UtilService::PostMore([
|
||
|
['e_id', 0],
|
||
|
['type', 1],
|
||
|
['questions_id', 0],
|
||
|
['user_answer', ''],
|
||
|
['answer', ''],
|
||
|
['is_correct', 0],
|
||
|
['score', 0]
|
||
|
], $this->request);
|
||
|
if ($data['e_id'] <= 0) return JsonService::fail('参数错误');
|
||
|
$res = ExaminationTestRecord::addExaminationTestRecord($data, $this->uid);
|
||
|
if ($res) return JsonService::successful('提交成功');
|
||
|
else return JsonService::fail('提交失败');
|
||
|
}
|
||
|
|
||
|
/**
|
||
|
* 提交试卷
|
||
|
*/
|
||
|
public function submitTestPaper()
|
||
|
{
|
||
|
$data = UtilService::PostMore([
|
||
|
['examination_id', 0],
|
||
|
['type', 1],
|
||
|
['duration', ''],
|
||
|
['score', '']
|
||
|
], $this->request);
|
||
|
$res = ExaminationRecord::submitExaminationRecord($data, $this->uid);
|
||
|
if ($res) return JsonService::successful('提交成功');
|
||
|
else return JsonService::fail(ExaminationRecord::getErrorInfo('提交失败'));
|
||
|
}
|
||
|
|
||
|
/**检测是否提交
|
||
|
* @return void
|
||
|
* @throws \think\db\exception\DataNotFoundException
|
||
|
* @throws \think\db\exception\ModelNotFoundException
|
||
|
* @throws \think\exception\DbException
|
||
|
*/
|
||
|
public function is_submit()
|
||
|
{
|
||
|
$data = UtilService::PostMore([
|
||
|
['examination_id', 0],
|
||
|
['type', 1],
|
||
|
], $this->request);
|
||
|
$record = ExaminationRecord::where(['id' => $data['examination_id'], 'type' => $data['type'], 'uid' => $this->uid])->find();
|
||
|
if(!$record) return JsonService::fail('记录不存在');
|
||
|
return JsonService::successful($record['is_submit']);
|
||
|
}
|
||
|
/**专题下关联的练习、考试 post提交
|
||
|
* @param $special_id
|
||
|
*/
|
||
|
public function specialTestPaper()
|
||
|
{
|
||
|
list($special_id, $type) = UtilService::PostMore([
|
||
|
['special_id', 0],
|
||
|
['type', 1],
|
||
|
], $this->request, true);
|
||
|
if (!$special_id) return JsonService::fail('缺少参数,无法访问');
|
||
|
$data = [];
|
||
|
switch ($type) {
|
||
|
case 1:
|
||
|
$relationship = 1;
|
||
|
break;
|
||
|
case 2:
|
||
|
$relationship = 2;
|
||
|
break;
|
||
|
}
|
||
|
$test_ids = Relation::setWhere($relationship, $special_id)->column('relation_id');
|
||
|
if (count($test_ids)) {
|
||
|
$data = TestPaper::PreExercisesWhere()->where('type', $type)->where('id', 'in', $test_ids)->order('sort desc,id desc')->select();
|
||
|
$data = count($data) > 0 ? $data->toArray() : [];
|
||
|
foreach ($data as $key => &$value) {
|
||
|
if ($type == 1) {
|
||
|
$record = ExaminationRecord::where(['test_id' => $value['id'], 'uid' => $this->uid, 'type' => 1])->order('id desc')->find();
|
||
|
if (!$record) $value['done'] = 0;
|
||
|
else $value['done'] = ExaminationTestRecord::where(['e_id' => $record['id'], 'uid' => $this->uid, 'type' => 1])->count();
|
||
|
} else if ($type == 2) {
|
||
|
$value['is_pay'] = (!$this->uid || $this->uid == 0) ? false : TestPaperObtain::PayTestPaper($value['id'], $this->uid, 2);
|
||
|
}
|
||
|
$value['answer'] = $value['answer'] + $value['fake_sales'];
|
||
|
}
|
||
|
}
|
||
|
return JsonService::successful($data);
|
||
|
}
|
||
|
|
||
|
/**
|
||
|
* 我的错题库列表
|
||
|
*/
|
||
|
public function userWrongBank()
|
||
|
{
|
||
|
list($page, $limit, $is_master) = UtilService::PostMore([
|
||
|
['page', 1],
|
||
|
['limit', 10],
|
||
|
['is_master', ''],
|
||
|
], $this->request, true);
|
||
|
$list = ExaminationWrongBank::userWrongBankList($this->uid, $page, $limit, $is_master);
|
||
|
return JsonService::successful($list);
|
||
|
}
|
||
|
|
||
|
/**获取错题库的试题
|
||
|
/**
|
||
|
* 我的错题库id列表
|
||
|
*/
|
||
|
public function userWrongBankIdArr()
|
||
|
{
|
||
|
list($id, $is_master, $order) = UtilService::PostMore([
|
||
|
['id', 0],
|
||
|
['is_master', ''],
|
||
|
['order', 1],
|
||
|
], $this->request, true);
|
||
|
$list = ExaminationWrongBank::getUserWrongBankIDList($this->uid, $is_master, $id, $order);
|
||
|
return JsonService::successful($list);
|
||
|
}
|
||
|
|
||
|
/**删除错题
|
||
|
* @param $id
|
||
|
*/
|
||
|
public function delWrongBank($id)
|
||
|
{
|
||
|
if (!$id) return JsonService::fail('缺少参数');
|
||
|
$res = ExaminationWrongBank::delUserWrongBank($id);
|
||
|
return JsonService::successful($res);
|
||
|
}
|
||
|
|
||
|
/**获取错题库的试题 未使用
|
||
|
* @throws \think\db\exception\DataNotFoundException
|
||
|
* @throws \think\db\exception\ModelNotFoundException
|
||
|
* @throws \think\exception\DbException
|
||
|
*/
|
||
|
public function lookTopicWrongBank()
|
||
|
{
|
||
|
list($is_master) = UtilService::PostMore([
|
||
|
['is_master', 0],
|
||
|
], $this->request, true);
|
||
|
$list = ExaminationWrongBank::getUserWrongBankListAll($this->uid, $is_master);
|
||
|
// foreach ($list as $key => &$value) {
|
||
|
// $value['special'] = Relation::getRelationSpecial(3, $value['questions_id']);
|
||
|
// }
|
||
|
return JsonService::successful($list);
|
||
|
}
|
||
|
|
||
|
/**获取单个错题
|
||
|
* @param $id
|
||
|
* @throws \think\db\exception\DataNotFoundException
|
||
|
* @throws \think\db\exception\ModelNotFoundException
|
||
|
* @throws \think\exception\DbException
|
||
|
*/
|
||
|
public function oneWrongBank($id)
|
||
|
{
|
||
|
if (!$id) return JsonService::fail('缺少参数,无法访问');
|
||
|
$wrong = ExaminationWrongBank::getUserWrongBankListOne($this->uid, $id);
|
||
|
$wrong['special'] = Relation::getRelationSpecial(3, $wrong['questions_id']);
|
||
|
return JsonService::successful($wrong);
|
||
|
}
|
||
|
|
||
|
/**
|
||
|
* 错题库未掌握试题提交
|
||
|
*/
|
||
|
public function submitWrongBank()
|
||
|
{
|
||
|
$data = UtilService::PostMore([
|
||
|
['wrong_id', 0],
|
||
|
['questions_id', 0],
|
||
|
['is_master', 0]
|
||
|
], $this->request);
|
||
|
if ((int)$data['wrong_id'] <= 0 || (int)$data['questions_id'] <= 0) return JsonService::fail('参数错误');
|
||
|
$res = ExaminationWrongBank::userSubmitWrongBank($data, $this->uid);
|
||
|
if ($res) return JsonService::successful('ok');
|
||
|
else return JsonService::fail('err');
|
||
|
}
|
||
|
|
||
|
/**
|
||
|
* 考试检测是否达到领取标准
|
||
|
* $test_id 试卷ID
|
||
|
*/
|
||
|
public function inspect($test_id = 0)
|
||
|
{
|
||
|
$res = CertificateRelated::getCertificateRelated($test_id, 0, 2, $this->uid);
|
||
|
if ($res) {
|
||
|
return JsonService::successful('ok');
|
||
|
} else {
|
||
|
return JsonService::fail('err');
|
||
|
}
|
||
|
}
|
||
|
|
||
|
/**用户领取证书
|
||
|
* $test_id 试卷ID
|
||
|
*/
|
||
|
public function getTheCertificate($test_id)
|
||
|
{
|
||
|
$res = CertificateRecord::getUserTheCertificate($test_id, 2, $this->uid);
|
||
|
if ($res) {
|
||
|
return JsonService::successful($res);
|
||
|
} else {
|
||
|
return JsonService::fail('领取失败');
|
||
|
}
|
||
|
}
|
||
|
|
||
|
/**
|
||
|
* 我的试卷
|
||
|
* @param int $type 1=练习 2=考试
|
||
|
*/
|
||
|
public function myTestPaper()
|
||
|
{
|
||
|
list($page, $limit, $type) = UtilService::PostMore([
|
||
|
['page', 1],
|
||
|
['limit', 10],
|
||
|
['type', 1]
|
||
|
], $this->request, true);
|
||
|
$list = TestPaperObtain::getUserTestPaper($type, $this->uid, $page, $limit);
|
||
|
return JsonService::successful($list);
|
||
|
}
|
||
|
|
||
|
/**
|
||
|
* 我的证书
|
||
|
*/
|
||
|
public function getUserCertificate()
|
||
|
{
|
||
|
list($page, $limit) = UtilService::PostMore([
|
||
|
['page', 1],
|
||
|
['limit', 10]
|
||
|
], $this->request, true);
|
||
|
$list = CertificateRecord::getUserCertificate($this->uid, $page, $limit);
|
||
|
return JsonService::successful($list);
|
||
|
}
|
||
|
|
||
|
/**查看证书
|
||
|
* @param $id
|
||
|
* @param $obtain
|
||
|
* @throws \think\db\exception\DataNotFoundException
|
||
|
* @throws \think\db\exception\ModelNotFoundException
|
||
|
* @throws \think\exception\DbException
|
||
|
*/
|
||
|
public function viewCertificate($id, $obtain)
|
||
|
{
|
||
|
$data = CertificateRecord::getCertificate($id, $obtain, $this->uid);
|
||
|
if ($data) {
|
||
|
$data['nickname'] = $this->userInfo['nickname'];
|
||
|
return JsonService::successful($data);
|
||
|
} else {
|
||
|
return JsonService::fail('关联证书已被移除');
|
||
|
}
|
||
|
}
|
||
|
}
|