会员可以在此提问,百战程序员老师有问必答
对大家有帮助的问答会被标记为“推荐”
看完课程过来浏览一下别人提的问题,会帮你学得更全面
截止目前,同学们一共提了 132468个问题
JAVA 全系列/第一阶段:JAVA 快速入门/变量、数据类型、运算符 34966楼

<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <title>Title</title>
    <script src="js/myAjax.js"></script>
</head>
<body>
 <button>发送请求</button>
 <script>
     /*var btn=document.querySelector('button');
     btn.onclick=function () {

     }*/

     function myAjax(paramsObj){
         //toLowerCase()将所有的都转为小写
         if (paramsObj.type.toLowerCase()=='get'){
             //封装get请求
             // console.log(paramsObj.data);
             //打印出来是对象,所以要先转换成数组
             var arr=[];
             for (var pro in paramsObj.data){
                 var str=pro+"="+paramsObj.data[pro];
                 arr.push(str);
             }
             //console.log(arr);//(2) ["username=test-beixi", "password=test-123456"]
             //将数组转换为字符串 以&作为分隔符
             var canshuStr=arr.join('&');
             //console.log(canshuStr);//username=test-beixi&password=test-123456
             // paramsObj.url+=canshuStr;
             //console.log(paramsObj.url);//3-封装Ajax.phpusername=test-beixi&password=test-123456
             /*在上面打印出来,路径后面没有?,所以要在这利用三目运算判断一下
              路径后面有没有?,==-1表示没有,就在路径后面加上?,如果有就加上
              字符串
              */
             paramsObj.url+=paramsObj.url.indexOf('?')==-1?'?'+canshuStr:'&'+canshuStr;
             // console.log(paramsObj.url);//3-封装Ajax.php?username=test-beixi&password=test-123456
         }else if(paramsObj.type.toLowerCase()=='post'){
             //封装post
             var formData=new FormData();
             //将数据放到对象里面
             for(var pro in paramsObj.data){
                 formData.append(pro,paramsObj.data[pro]);
             }
         }else{
             console.log('请求类型有误');
         }
         //创建xhr对象
         var xhr=new XMLHttpRequest();
         xhr.onreadystatechange=function(){
             if (xhr.readyState==4){
                 if (xhr.status==200){
                     //反馈回来的数据
                     paramsObj.success(xhr.responseText);
                 }
             }

         };
         //准备发送
         xhr.open(paramsObj.type,paramsObj.url,true);
         //发送请求
         if (paramsObj.type.toLowerCase()=='get'){
             xhr.send(null);
         }else if (paramsObj.type.toLowerCase()=='post'){
             xhr.send(formData);
         }else{
             console.log('请求类型有误');
         }

     }
     myAjax({
         type:'get',
         url:'3-封装Ajax.php',
         data:{
             username:'test-beixi',
             password:'test-123456'
         },
         success:function (res) {
             console.log(res);
         }
     })
 </script>
</body>
</html>

<?php?
 $success=array('msg'=>'ok','info'=>$_GET);
 echo json_encode($success);
>

老师我这是哪里出错啦,打印出来的是

blob.png

WEB前端全系列/第六阶段:Http服务与Ajax模块(旧)/Http服务与Ajax编程 34967楼
JAVA 全系列/第十八阶段:亿级高并发电商项目_架构/编码(旧)/电商:基于SpringSecurity实现后台登录功能 34969楼
JAVA 全系列/第六阶段:项目管理与SSM框架/Spring 34972楼

package com.bjsxt.shiro;

import org.apache.shiro.SecurityUtils;
import org.apache.shiro.authc.IncorrectCredentialsException;
import org.apache.shiro.authc.UnknownAccountException;
import org.apache.shiro.authc.UsernamePasswordToken;
import org.apache.shiro.config.IniSecurityManagerFactory;
import org.apache.shiro.mgt.SecurityManager;
import org.apache.shiro.subject.Subject;
import org.apache.shiro.util.Factory;

public class TestB {

    public static void main(String[] args) {

        /*Realm*/

        //[1]解析shiro.ini文件
        Factory<SecurityManager>  factory =new IniSecurityManagerFactory("classpath:shiro-jdbc2.ini");

        //[2]通过SecurityManager工厂获得SecurityManager实例
        SecurityManager securityManager = factory.getInstance();

        //[3]把SecurityManager对象设置到运行环境中
        SecurityUtils.setSecurityManager(securityManager);

        //[4]通过SecurityUtils获得主体subject
        Subject subject = SecurityUtils.getSubject();

        //[5]书写自己输入的账号和密码---相当于用户自己输入的账号和密码
        //我们拿着自己书写用户名密码去和shiro.ini 文件中的账号密码比较
        UsernamePasswordToken  token =new UsernamePasswordToken("root","123");

        try {
            //[6]进行身份的验证
            subject.login(token);

            //[7]通过方法判断是否登录成功

            if(subject.isAuthenticated()){
                System.out.println("登录成功");

                //授权的校验
                System.out.println("是否存在该菜单:"+subject.isPermitted("updateUser2123"));

            }
        } catch (IncorrectCredentialsException e) {

            System.out.println("登录失败");


        }catch (UnknownAccountException e){

            System.out.println("用户名不正确");
        }
    }
}

要不要把学过的内容都背下来,比如上面的例子

JAVA 全系列/第九阶段:权限控制与安全认证/Shiro(旧) 34973楼

根据条件查询用户,不区分条件大小写的吗。我查询条件是usersex = male 可是查出来的包括usersex = MALE 的 


UsersMapper.xml

<!--    根据用户给定条件查询-->
<select id="selectUsersByProperty" resultType="Users">
    select * from users where  1=1
    <if test="userid != 0">
         and userid = #{userid}
    </if>
    <if test="username != null and username != ''">
         and username = #{username}
    </if>
    <if test="usersex != null and usersex != ''">
         and usersex = #{usersex}
    </if>
</select>


UsersMapper

List<Users> selectUsersByProperty(Users users);


UsersService

List<Users> findUsersByProperty(Users users);


UsersServiceImpl

/**
 * 根据给定条件查询用户
 * @param users
 * @return
 */
@Override
public List<Users> findUsersByProperty(Users users) {
    List<Users> list = null;
    try{
        SqlSession sqlSession = MybatisUtils.getSqlSession();
        UsersMapper mapper = sqlSession.getMapper(UsersMapper.class);
        list = mapper.selectUsersByProperty(users);

    }catch (Exception e){
        e.printStackTrace();
    }finally {
        MybatisUtils.closeSqlSession();
    }

    return list;
}


测试代码

public class FindUsersByPropertyTeset {
    public static void main(String[] args) {
        UsersServices usersServices = new UsersServicesImpl();
        Users users = new Users();
        users.setUsersex("male");
        List<Users> list = usersServices.findUsersByProperty(users);
        list.forEach(System.out::println);

    }
}


运行结果

image.png

JAVA 全系列/第六阶段:项目管理与SSM框架/Mybatis 34975楼
JAVA 全系列/第六阶段:项目管理与SSM框架/Mybatis 34977楼
Python 全系列/第二阶段:Python 深入与提高/游戏开发-坦克大战 34980楼

课程分类

百战程序员微信公众号

百战程序员微信小程序

©2014-2025百战汇智(北京)科技有限公司 All Rights Reserved 北京亦庄经济开发区科创十四街 赛蒂国际工业园
网站维护:百战汇智(北京)科技有限公司
京公网安备 11011402011233号    京ICP备18060230号-3    营业执照    经营许可证:京B2-20212637