I am using PostgreSQL for storing username and their corresponding salted and hashed password but it is continuously giving me this error.
LINE 1: ...egister where USERNAME = 'siddharth' and PASSWORD = '\x24326...
^
HINT: No operator matches the given name and argument types. You might need to add explicit type casts.
My Table Name is hassle_free_register and its structure is as follows as :
Table "public.hassle_free_register"
Column | Type | Collation | Nullable | Default
----------+------------------------+-----------+----------+-------------------------------------------------------
user_id | integer | | not null | nextval('hassle_free_register_user_id_seq'::regclass)
username | character varying(255) | | not null |
password | character varying(255) | | not null |
Indexes:
"hassle_free_register_pkey" PRIMARY KEY, btree (user_id)
"hassle_free_register_username_key" UNIQUE CONSTRAINT, btree (username)
CODE for registering the user :-
@app.route('/register' ,methods =['POST'])
def register():
try:
NAME = request.form['USER_NAME']
PASSWORD = request.form['USER_PASSWORD']
if(len(NAME)==0):
return jsonify({"message" :"USERNAME CANNOT BE EMPTY"}),400
if(len(PASSWORD)<=8):
return jsonify({"message" :"PASSWORD LENGTH TOO SHORT"}),400
if(len(PASSWORD)>=30):
return jsonify({"message" :"PASSWORD LENGTH TOO LONG"}),400
HASHEDPASS = bcrypt.hashpw(PASSWORD.encode('utf-8'),bcrypt.gensalt())
mycursor.execute("insert into hassle_free_register (USERNAME,PASSWORD) values(%s, %s);",(NAME,HASHEDPASS))
#ERROR IS OCCURING IN THIS LINE
mycursor.execute("select USER_ID from Hassle_Free_Register where USERNAME = %s and PASSWORD = %s;",(NAME,HASHEDPASS))
data = mycursor.fetchone()
print(data)
mycursor.execute("create table {TABLENAME} (PASSWORD_ID int SERIAL NOT NULL PRIMARY KEY,APP_NAME varchar(255) NOT NULL, APP_USERNAME varchar(255) NOT NULL , APP_PASSWORD varchar(255) NOT NULL);".format(TABLENAME = NAME + "_" + str(data[0])))
mydb.commit()
return jsonify("REGISTERED SUCCESSFULLY")
except TypeError as error:
print(error)
return jsonify({"message":str(error)}),403
except ValueError as error:
print(error)
return jsonify({"message":str(error)}),403
except psycopg2.Error as error:
print(error)
return jsonify({"message":str(error)}),403
(EDITED AFTER COMMENTS) I am new to Python and postgrSQL. Please Help !
I ran the query which was giving the error in the SQL shell (psql) but it ran successfully their.
QUERY :-
hassle_free=# select USER_ID from hassle_free_register where USERNAME = 'siddharth' and PASSWORD = '\x24326224313224587174764d532e6265334d6654354e47514a6d73674f6d72327a75723966747a42542e5a2e4f48374e74446d6e76355353752e7461';
RESULT :-
user_id
---------
39
(1 row)
Please Help.