java - 我怎样才能让这个用户(普通用户)获得使用该程序的权限

标签 java mysql stored-procedures sql-grant

//这是我的MySQL代码

START TRANSACTION;
BEGIN;
DELIMITER //
CREATE PROCEDURE ViewTempUserInfo (IN Log_Name VARCHAR(45),IN user_Pass VARCHAR(45), 
OUT ID_ INT, out Email VARCHAR(60), out UName VARCHAR(60))

BEGIN

SELECT Costumors_ID into ID_ FROM costumors 
where Costumors_ID= (select Costumors_ID from costumors 
where costumors.Cos_Login_Name = Log_Name and costumors.Cos_Password=user_Pass);

select Cos_Name into UName FROM costumors
where Costumors_ID= ID_;

select Cos_Email into Email FROM costumors 
where Costumors_ID= ID_;

END //
DELIMITER ;
COMMIT;

call ViewTempUserInfo('r','r',@A, @B,@C);

select @A, @B,@C;

GRANT EXECUTE ON PROCEDURE ViewTempUserInfo TO NormalUsers@'%' IDENTIFIED BY '2345NormalUsers2345';
FLUSH PRIVILEGES;

//这是我的Java代码

//STEP 1. Import required packages
import java.sql.*;
import java.util.Properties;

public class Procedure {
   // JDBC driver name and database URL

   static final String DB_URL = "jdbc:mysql://127.0.0.1/testarxampp?allowMultiQueries=true";


    private static String userName= "root";                     //NormalUsers
    private static String password = "DatabasteknikKursen12";   //2345NormalUsers2345
    private static String serverName = "127.0.0.1";
    private static String portNumber = "3306";
    private static String dbName = "testarxampp";

   //  Database credentials
   //static final String USER = "NormalUsers";
   //static final String PASS = "2345NormalUsers2345";

   public static void main(String[] args) {
   Connection conn = null;
   CallableStatement stmt = null;
   try{
      //STEP 2: Register JDBC driver
      Class.forName("com.mysql.jdbc.Driver");

      //STEP 3: Open a connection
      System.out.println("Connecting to database...");
      Properties connectionProps = new Properties();
      connectionProps.put("user", userName);
      connectionProps.put("password", password );
      conn = DriverManager.getConnection("jdbc:mysql://" + serverName + ":" + portNumber + "/" + dbName, connectionProps);

      //STEP 4: Execute a query
        String userNamex = "abli";
        String Passwordx = "ablinana";
      System.out.println("Creating statement...");
      String sql = "{call ViewTempUserInfo(?, ?, ?, ?, ?)}";
      stmt = conn.prepareCall(sql);

      //Bind IN parameter first, then bind OUT parameter

      stmt.setString(1, userNamex); // This would set ID as 102
      // Because second parameter is OUT so register it
      stmt.setString(2, Passwordx);

      stmt.registerOutParameter(3, java.sql.Types.INTEGER);
      stmt.registerOutParameter(4, java.sql.Types.VARCHAR);
      stmt.registerOutParameter(5, java.sql.Types.VARCHAR);

      //Use execute method to run stored procedure.
      System.out.println("Executing stored procedure..." );
      stmt.execute();

      //Retrieve employee name with getXXX method

      System.out.println("Emp Name with ID:" + 
              userNamex + " is " + Passwordx);



      System.out.println("ID    : " + stmt.getInt(3));
      System.out.println("Email    : " + stmt.getString(4));
      System.out.println("name    : " + stmt.getString(5));

      stmt.close();
      conn.close();
   }catch(SQLException se){
      //Handle errors for JDBC
      se.printStackTrace();
   }catch(Exception e){
      //Handle errors for Class.forName
      e.printStackTrace();
   }finally{
      //finally block used to close resources
      try{
         if(stmt!=null)
            stmt.close();
      }catch(SQLException se2){
      }// nothing we can do
      try{
         if(conn!=null)
            conn.close();
      }catch(SQLException se){
         se.printStackTrace();
      }//end finally try
   }//end try
    System.out.println("Goodbye!");

一切正常,我得到以下信息

Connecting to database...
Creating statement...
Executing stored procedure...
Emp Name with ID:abli is ablinana
ID    : 6
Email    : asdf@asdf.se
name    : asdf
Goodbye!

但是如果我改变这些行

private static String userName= "root";                     //NormalUsers
private static String password = "DatabasteknikKursen12";   //2345NormalUsers2345

对此

private static String userName= "NormalUsers";                      //NormalUsers
private static String password = "2345NormalUsers2345"; //2345NormalUsers2345

我收到以下错误。

Connecting to database...
Creating statement...
java.sql.SQLException: Parameter number 3 is not an OUT parameter
    at com.mysql.jdbc.SQLError.createSQLException(SQLError.java:996)
    at com.mysql.jdbc.SQLError.createSQLException(SQLError.java:935)
    at com.mysql.jdbc.SQLError.createSQLException(SQLError.java:924)
    at com.mysql.jdbc.SQLError.createSQLException(SQLError.java:870)
    at com.mysql.jdbc.CallableStatement.checkIsOutputParam(CallableStatement.java:659)
    at com.mysql.jdbc.CallableStatement.registerOutParameter(CallableStatement.java:1860)
    at Procedure.main(Procedure.java:48)
Goodbye!

了解我在某处做错了什么或如何在不给予 NormalUsers 所有特权作为 root 用户的情况下解决问题的人。我使用 mysql-connector-java-1.5.34-bin 并测试切换到 mysql-connector-java-5.1.4 但这没有帮助。在我的许多java类中都有类似的问题。应该足够了:

GRANT EXECUTE ON PROCEDURE ViewTempUserInfo TO NormalUsers@'%' IDENTIFIED BY '2345NormalUsers2345';
FLUSH PRIVILEGES;

?????????????求求你解释一下????????????????????????

在类似的帖子中,有人给出了我不明白的答案。除了这个,现在什么都试过了

stored procedures executed through jdbc

TLDR; Change your Callable Statement to reference parameters by index instead of name.

After having a similar problem I updated my JDBC driver mysql-connector-java-5.1.26-bin.jar. The error then changed from

    User does not have access to metadata required to determine stored procedure parameter types. If rights can not be granted, configure connection with "noAccessToProcedureBodies=true" to have driver generate parameters that represent INOUT strings irregardless of actual parameter types.

to

    No access to parameters by name when connection has been configured not to access procedure bodies

I changed my Callable Statement to reference parameters by index instead of name, and hey presto it works.

Updating the driver may not be necessary, just knowing to use indexes instead of names when you don't have metadata access or routine body access.

Good Luck
share|edit

answered Aug 2 '13 at 13:26
Kickaha
603319

有人知道他的意思 将 CallableStatement 更改为通过索引而不是名称来引用参数 应该更改什么,有人可以解释一下。

最佳答案

尝试指定数据库名称:

GRANT EXECUTE ON PROCEDURE testarxampp.ViewTempUserInfo TO 'NormalUsers'@'%' IDENTIFIED BY '2345NormalUsers2345';
FLUSH PRIVILEGES;

关于java - 我怎样才能让这个用户(普通用户)获得使用该程序的权限,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/27474875/

相关文章:

java - 用一种方法使用 3 种可能的正则表达式扫描文件

MySQL 查询 "self-tabled"行

php - 确定 Laravel 5.7 上每个用户级别/角色的布局

python - 在 Mysql 过程中循环遍历字符串

sql - 插入多个表时,解决这个问题的最佳方法是什么?

c# - 使用存储过程检查用户名是否存在于 asp.net 中并将值添加到 Registration.aspx

java - Camel 消费者: Dynamic Delay Times

java - 使用 Spring security Javaconfig 进行基本和基于表单的身份验证

java - AsyncHttpClient 发布并获取 JSON 响应

php - 尝试从表中获取信息,获取资源值