mirror of
https://github.com/renbaoshuo/S2OJ.git
synced 2024-12-24 13:01:53 +00:00
0ec962b4af
In order to support PHP7, change the way to operate database. PHP7 removed the mysql extension, so the old way to operate database is not usable. This commit use a new way to operate database. BREAKING CHANGE: the way to operate database has changed.
195 lines
7.2 KiB
PHP
195 lines
7.2 KiB
PHP
<?php
|
||
if (!Auth::check()) {
|
||
redirectToLogin();
|
||
}
|
||
function handlePost() {
|
||
global $myUser;
|
||
if (!isset($_POST['old_password']))
|
||
{
|
||
return '无效表单';
|
||
}
|
||
$old_password = $_POST['old_password'];
|
||
if (!validatePassword($old_password) || !checkPassword($myUser, $old_password))
|
||
{
|
||
return "失败:密码错误。";
|
||
}
|
||
if ($_POST['ptag'])
|
||
{
|
||
$password = $_POST['password'];
|
||
if (!validatePassword($password))
|
||
{
|
||
return "失败:无效密码。";
|
||
}
|
||
$password = getPasswordToStore($password, $myUser['username']);
|
||
DB::update("update user_info set password = '$password' where username = '{$myUser['username']}'");
|
||
}
|
||
|
||
$email = $_POST['email'];
|
||
if (!validateEmail($email))
|
||
{
|
||
return "失败:无效电子邮箱。";
|
||
}
|
||
$esc_email = DB::escape($email);
|
||
DB::update("update user_info set email = '$esc_email' where username = '{$myUser['username']}'");
|
||
|
||
if ($_POST['Qtag'])
|
||
{
|
||
$qq = $_POST['qq'];
|
||
if (!validateQQ($qq))
|
||
{
|
||
return "失败:无效QQ。";
|
||
}
|
||
$esc_qq = DB::escape($qq);
|
||
DB::update("update user_info set qq = '$esc_qq' where username = '{$myUser['username']}'");
|
||
}
|
||
else
|
||
DB::update("update user_info set QQ = NULL where username = '{$myUser['username']}'");
|
||
if ($_POST['sex'] == "U" || $_POST['sex'] == 'M' || $_POST['sex'] == 'F')
|
||
{
|
||
$sex = $_POST['sex'];
|
||
$esc_sex = DB::escape($sex);
|
||
DB::update("update user_info set sex = '$esc_sex' where username = '{$myUser['username']}'");
|
||
}
|
||
|
||
if (validateMotto($_POST['motto'])) {
|
||
$esc_motto = DB::escape($_POST['motto']);
|
||
DB::update("update user_info set motto = '$esc_motto' where username = '{$myUser['username']}'");
|
||
}
|
||
|
||
return "ok";
|
||
}
|
||
if (isset($_POST['change'])) {
|
||
die(handlePost());
|
||
}
|
||
?>
|
||
<?php
|
||
$REQUIRE_LIB['dialog'] = '';
|
||
$REQUIRE_LIB['md5'] = '';
|
||
?>
|
||
<?php echoUOJPageHeader(UOJLocale::get('modify my profile')) ?>
|
||
<h2 class="page-header"><?= UOJLocale::get('modify my profile') ?></h2>
|
||
<form id="form-update" class="form-horizontal">
|
||
<h4><?= UOJLocale::get('please enter your password for authorization') ?></h4>
|
||
<div id="div-old_password" class="form-group">
|
||
<label for="input-old_password" class="col-sm-2 control-label"><?= UOJLocale::get('password') ?></label>
|
||
<div class="col-sm-3">
|
||
<input type="password" class="form-control" name="old_password" id="input-old_password" placeholder="<?= UOJLocale::get('enter your password') ?>" maxlength="20" />
|
||
<span class="help-block" id="help-old_password"></span>
|
||
</div>
|
||
</div>
|
||
<h4><?= UOJLocale::get('please enter your new profile') ?></h4>
|
||
<div id="div-password" class="form-group">
|
||
<label for="input-password" class="col-sm-2 control-label"><?= UOJLocale::get('new password') ?></label>
|
||
<div class="col-sm-3">
|
||
<input type="password" class="form-control" id="input-password" name="password" placeholder="<?= UOJLocale::get('enter your new password') ?>" maxlength="20" />
|
||
<input type="password" class="form-control top-buffer-sm" id="input-confirm_password" placeholder="<?= UOJLocale::get('re-enter your new password') ?>" maxlength="20" />
|
||
<span class="help-block" id="help-password"><?= UOJLocale::get('leave it blank if you do not want to change the password') ?></span>
|
||
</div>
|
||
</div>
|
||
<div id="div-email" class="form-group">
|
||
<label for="input-email" class="col-sm-2 control-label"><?= UOJLocale::get('email') ?></label>
|
||
<div class="col-sm-3">
|
||
<input type="email" class="form-control" name="email" id="input-email" value="<?=$myUser['email']?>" placeholder="<?= UOJLocale::get('enter your email') ?>" maxlength="50" />
|
||
<span class="help-block" id="help-email"></span>
|
||
</div>
|
||
</div>
|
||
<div id="div-qq" class="form-group">
|
||
<label for="input-qq" class="col-sm-2 control-label"><?= UOJLocale::get('QQ') ?></label>
|
||
<div class="col-sm-3">
|
||
<input type="text" class="form-control" name="qq" id="input-qq" value="<?= $myUser['qq'] != 0 ? $myUser['qq'] : '' ?>" placeholder="<?= UOJLocale::get('enter your QQ') ?>" maxlength="50" />
|
||
<span class="help-block" id="help-qq"></span>
|
||
</div>
|
||
</div>
|
||
<div id="div-sex" class="form-group">
|
||
<label for="input-sex" class="col-sm-2 control-label"><?= UOJLocale::get('sex') ?></label>
|
||
<div class="col-sm-3">
|
||
<select class="form-control" id="input-sex" name="sex">
|
||
<option value="U"<?= Auth::user()['sex'] == 'U' ? ' selected="selected"' : ''?>><?= UOJLocale::get('refuse to answer') ?></option>
|
||
<option value="M"<?= Auth::user()['sex'] == 'M' ? ' selected="selected"' : ''?>><?= UOJLocale::get('male') ?></option>
|
||
<option value="F"<?= Auth::user()['sex'] == 'F' ? ' selected="selected"' : ''?>><?= UOJLocale::get('female') ?></option>
|
||
</select>
|
||
</div>
|
||
</div>
|
||
<div id="div-motto" class="form-group">
|
||
<label for="input-motto" class="col-sm-2 control-label"><?= UOJLocale::get('motto') ?></label>
|
||
<div class="col-sm-3">
|
||
<textarea class="form-control" id="input-motto" name="motto"><?=HTML::escape($myUser['motto'])?></textarea>
|
||
<span class="help-block" id="help-motto"></span>
|
||
</div>
|
||
</div>
|
||
<div class="form-group">
|
||
<div class="col-sm-offset-2 col-sm-3">
|
||
<p class="form-control-static"><strong><?= UOJLocale::get('change avatar help') ?></strong></p>
|
||
</div>
|
||
</div>
|
||
<div class="form-group">
|
||
<div class="col-sm-offset-2 col-sm-3">
|
||
<button type="submit" id="button-submit" class="btn btn-default"><?= UOJLocale::get('submit') ?></button>
|
||
</div>
|
||
</div>
|
||
</form>
|
||
|
||
<script type="text/javascript">
|
||
function validateUpdatePost() {
|
||
var ok = true;
|
||
ok &= getFormErrorAndShowHelp('email', validateEmail);
|
||
ok &= getFormErrorAndShowHelp('old_password', validatePassword);
|
||
|
||
if ($('#input-password').val().length > 0)
|
||
ok &= getFormErrorAndShowHelp('password', validateSettingPassword);
|
||
if ($('#input-qq').val().length > 0)
|
||
ok &= getFormErrorAndShowHelp('qq', validateQQ);
|
||
ok &= getFormErrorAndShowHelp('motto', validateMotto);
|
||
return ok;
|
||
}
|
||
function submitUpdatePost() {
|
||
if (!validateUpdatePost())
|
||
return;
|
||
$.post('/user/modify-profile', {
|
||
change : '',
|
||
etag : $('#input-email').val().length,
|
||
ptag : $('#input-password').val().length,
|
||
Qtag : $('#input-qq').val().length,
|
||
email : $('#input-email').val(),
|
||
password : md5($('#input-password').val(), "<?= getPasswordClientSalt() ?>"),
|
||
old_password : md5($('#input-old_password').val(), "<?= getPasswordClientSalt() ?>"),
|
||
qq : $('#input-qq').val(),
|
||
sex : $('#input-sex').val(),
|
||
motto : $('#input-motto').val()
|
||
}, function(msg) {
|
||
if (msg == 'ok') {
|
||
BootstrapDialog.show({
|
||
title : '修改成功',
|
||
message : '用户信息修改成功',
|
||
type : BootstrapDialog.TYPE_SUCCESS,
|
||
buttons : [{
|
||
label: '好的',
|
||
action: function(dialog) {
|
||
dialog.close();
|
||
}
|
||
}],
|
||
onhidden : function(dialog) {
|
||
window.location.href = '/user/profile/<?=$myUser['username']?>';
|
||
}
|
||
});
|
||
} else {
|
||
BootstrapDialog.show({
|
||
title : '修改失败',
|
||
message : msg,
|
||
type : BootstrapDialog.TYPE_DANGER,
|
||
buttons: [{
|
||
label: '好的',
|
||
action: function(dialog) {
|
||
dialog.close();
|
||
}
|
||
}],
|
||
});
|
||
}
|
||
});
|
||
}
|
||
$(document).ready(function(){$('#form-update').submit(function(e) {submitUpdatePost();e.preventDefault();});
|
||
});
|
||
</script>
|
||
<?php echoUOJPageFooter() ?>
|
||
|