草庐IT

php - Jquery 登录表单让我发疯

coder 2024-04-22 原文

所以我有一个主页,用户可以在其中登录。一旦他们登录,我需要他们将他们重定向到 index.php,它只提取那里的信息。 Jquery 调用 index.php,在其中对 Mysql 运行检查,如果用户不存在,它会警告用户不是有效用户。现在,如果需要,我需要将它们发送回 index.php。 她的是 index.php

    <?php
    include_once 'includes/membersclass.php';
    session_start();
    $member = new MEMBERS();

    if(!isset($_SESSION['id'])) {
        if($_POST['action'] == true) {
            $result = $member->login($_POST);
            if($result) {
                $_SESSION['id'] = $result;
                echo $_SESSION['id'];
            } else {
                 return false;
            }
        } 

        if($_POST['signup'] == 'true') {
            $result = $member->signup($_POST);
            if($result) {
                $_SESSION['id'] = $result;
            } else {
                header("Location: root.php");
            }
        } 
    }
?>

<!DOCTYPE html>
<html>
    <head>
        <title></title>
        <meta http-equiv="Content-Type" content="text/html; charset=UTF-8">
        <link rel='stylesheet' type='text/css' href='css/members.css' />
    </head>
    <body>
        <div id="calendar_container">
            <?php $member->drawCalendar(2, 2011); echo $_SESSION['id']; ?>
        </div>
    </body>
    </html>

如您所见,Jquery 对 index.php 进行初始调用并返回响应。我将 session 设置为存储用户 ID。在同一页面上将显示用户个人资料。成功登录后如何返回此处。我什至做得对吗,如果这与 PHP 分开开始。 Uggghhh,请帮忙。

最佳答案

问题有点模糊,但如果我理解正确的话,你想在成功登录后重新加载 index.php 页面。

if(!isset($_SESSION['id'])) {
    if($_POST['action'] == true) {
        $result = $member->login($_POST);
        if($result) {
            $_SESSION['id'] = $result;
            echo $_SESSION['id'];
        } else {
             return false;
        }
    } 

如果我没记错的话,这段代码会检查用户是否已经登录。如果没有,您将检查前一个 Jquery 页面是否给出了“操作”(我假设是登录调用)或“注册”(我假设是创建一个新帐户)。

在这种情况下,如果选择了“action”,则检查用户是否存在($result = $member->login($_POST);),如果存在,则创建 session ID 和索引-页面应显示个人资料。

由于 $_SESSION['id'] 仅在页面加载后分配,因此它不会检查 $_SESSION['id'] 是否已再次分配。所以你必须重新加载页面才能执行此操作:

if(!isset($_SESSION['id'])) {
    if($_POST['action'] == true) {
        $result = $member->login($_POST);
        if($result) {
            $_SESSION['id'] = $result;
            echo $_SESSION['id'];
            header("Location: index.php");

        } else {
             return false;
        }
    } 

现在它会再次调用 index.php,它会经过 if(!isset($_SESSION['id'])) 部分,因为这次创建了 session ,然后转到代码(还没有出现在这里?),它将处理配置文件。

我必须在这里假设很多,但告诉我我有多接近。

附言:

if($_POST['action'] == true)

和:

if($_POST['signup'] == 'true')

一旦你有 true 没有引号,一次有。我想你只是想检查设置了哪一个?这就足够了:

if(isset($_POST['signup']))

if(isset($_POST['action']))

使代码更一致,更不容易出错。

关于php - Jquery 登录表单让我发疯,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/7700642/

有关php - Jquery 登录表单让我发疯的更多相关文章

  1. ruby-on-rails - Rails 编辑表单不显示嵌套项 - 2

    我得到了一个包含嵌套链接的表单。编辑时链接字段为空的问题。这是我的表格:Editingkategori{:action=>'update',:id=>@konkurrancer.id})do|f|%>'Trackingurl',:style=>'width:500;'%>'Editkonkurrence'%>|我的konkurrencer模型:has_one:link我的链接模型:classLink我的konkurrancer编辑操作:defedit@konkurrancer=Konkurrancer.find(params[:id])@konkurrancer.link_attrib

  2. ruby - 如何在 Rails 4 中使用表单对象之前的验证回调? - 2

    我有一个服务模型/表及其注册表。在表单中,我几乎拥有服务的所有字段,但我想在验证服务对象之前自动设置其中一些值。示例:--服务Controller#创建Action:defcreate@service=Service.new@service_form=ServiceFormObject.new(@service)@service_form.validate(params[:service_form_object])and@service_form.saverespond_with(@service_form,location:admin_services_path)end在验证@ser

  3. jquery - 我的 jquery AJAX POST 请求无需发送 Authenticity Token (Rails) - 2

    rails中是否有任何规定允许站点的所有AJAXPOST请求在没有authenticity_token的情况下通过?我有一个调用Controller方法的JqueryPOSTajax调用,但我没有在其中放置任何真实性代码,但调用成功。我的ApplicationController确实有'request_forgery_protection'并且我已经改变了config.action_controller.consider_all_requests_local在我的environments/development.rb中为false我还搜索了我的代码以确保我没有重载ajaxSend来发送

  4. jquery - 如何将 AJAX 变量从 jQuery 传递到他们的 Controller ? - 2

    我有一个电子邮件表格。但是我正在制作一个测试电子邮件表单,用户可以在其中添加一个唯一的电子邮件,并让电子邮件测试将其发送到该特定电子邮件。为了简单起见,我决定让测试电子邮件通过ajax执行,并将整个内容粘贴到另一个电子邮件表单中。我不知道如何将变量从我的HAML发送到我的Controllernew.html.haml-form_tagadmin_email_blast_pathdoSubject%br=text_field_tag'subject',:class=>"mass_email_subject"%brBody%br=text_area_tag'message','',:nam

  5. ruby-on-rails - 从 ActiveAdmin has_many 表单助手中删除 "Add new"按钮 - 2

    我在事件管理员编辑页面中有嵌套资源,但我只想允许管理员编辑现有资源的内容,而不是添加新的嵌套资源。我的代码看起来像这样:formdo|f|f.inputsdof.input:authorf.input:contentf.has_many:commentsdo|comment_form|comment_form.input:contentcomment_form.input:_destroy,as::boolean,required:false,label:'Remove'endendf.actionsend但它在输入下添加了“添加新评论”按钮。我怎样才能禁用它,并只为主窗体保留f.ac

  6. ruby - 使用 Ruby 和 Mechanize 登录网站 - 2

    我需要从站点抓取数据,但它需要我先登录。我一直在使用hpricot成功地抓取其他网站,但我是使用mechanize的新手,我真的对如何使用它感到困惑。我看到这个例子经常被引用:require'rubygems'require'mechanize'a=Mechanize.newa.get('http://rubyforge.org/')do|page|#Clicktheloginlinklogin_page=a.click(page.link_with(:text=>/LogIn/))#Submittheloginformmy_page=login_page.form_with(:act

  7. ruby-on-rails - 用于 Rails 的 HAML 表单 - 2

    我目前正在尝试将ERB布局转换为HAML。这是我不断收到的错误:index.html.haml:18:syntaxerror,unexpected')'));}\n#{_hamlout.format_...这是HAML页面:.row-fluid.span6%h2TodoList.span6%h2{:style=>"text-align:right;"}document.write(today)%hr.divider.row-fluid.span6%h2.small_headNewTask=render:partial=>'layouts/form_errors',:locals=>{:

  8. ruby-on-rails - 如何在 Rails 中为现有模型生成表单? - 2

    为现有模型生成单个文件(_form.html.erb)的命令是什么?在Rails3中工作。谢谢。 最佳答案 这听起来可能很傻,但请听我说完……当我想开始清洁时,我自己也做过几次这样的事情。以下是一个脚本,它将读取您的模式并生成必要的生成命令来重现它:require'rubygems'require'active_support/core_ext'schema=File.read('db/schema.rb')schema.scan(/create_table"(\w+)",.*?\n(.*?)\nend/m).eachdo|name

  9. ruby-on-rails - 这个 C 和 PHP 程序员如何学习 Ruby 和 Rails? - 2

    按照目前的情况,这个问题不适合我们的问答形式。我们希望答案得到事实、引用或专业知识的支持,但这个问题可能会引发辩论、争论、投票或扩展讨论。如果您觉得这个问题可以改进并可能重新打开,visitthehelpcenter指导。关闭9年前。我来自C、php和bash背景,很容易学习,因为它们都有相同的C结构,我可以将其与我已经知道的联系起来。然后2年前我学了Python并且学得很好,Python对我来说比Ruby更容易学。然后从去年开始,我一直在尝试学习Ruby,然后是Rails,我承认,直到现在我还是学不会,讽刺的是那些打着简单易学的烙印,但是对于我这样一个老练的程序员来说,我只是无法将它

  10. jquery - 如何在 rails 3.1 上安装 jQuery - 2

    我以为它已经安装了,但在我的gemfile中有gem"jquery-rails"但是在我的asset/javascripts文件夹中accounts.js.coffeeapplication.js都被注释掉了这是我的虚拟railsapplication但是在源代码中没有jQuery并且删除链接不起作用......任何想法都丢失了 最佳答案 看看thisRailscast.您可能需要检查application.js文件并确保它包含以下语句。//=requirejquery//=requirejquery_ujs

随机推荐