Я окончательно решил это !!
в классе Conexion y удалил статический финал и я создал конструктор для этого класса
public class Conexion {
public Conexion(){
}
public Connection getConecction()
{
Connection con = null;
try{
Class.forName("com.mysql.jdbc.Driver");
con = DriverManager.getConnection("jdbc:mysql://localhost:3306/controldecalidad", "root", "");
}catch(SQLException ex){
}
catch(Exception ex){
}
return con;
}
}
затем я создалкласс, у которого есть все операции
public class Operaciones
{
Conexion conexion;
public Operaciones()
{
conexion = new Conexion();
}
public boolean registra_rechazo(String SKU,String fecha,String num_captura,int pesoCaptura)
{
Boolean bandera=false;
try
{
Connection conn = conexion.getConecction();
java.util.Date utilStartDate = new java.util.Date(fecha);
java.sql.Date sqlStartDate = new java.sql.Date(utilStartDate.getTime());
String sql = "INSERT INTO registra_rechazo VALUES(?,?,?,?)";
PreparedStatement pst = conn.prepareStatement(sql);
pst.setString(1, SKU);
pst.setDate(2, sqlStartDate);
pst.setString(3, num_captura);
pst.setInt(4, pesoCaptura);
if(pst.executeUpdate()!=-1){
bandera = true;
return bandera;
}
else{
bandera = false;
return bandera;
}
}
catch(SQLException Ex)
{
}
return bandera;
}
}
, затем я вызываю метод в веб-службе, но сначала веб-метод должен быть создан с помощью операции добавления в веб-службе, подобной изображению
https://i.stack.imgur.com/HjAHk.png
Я не знаю, почему, но метод работает, только если вы создали метод с этим мастером
@WebMethod(operationName = "operation")
public boolean operation(@WebParam(name = "SKU") String SKU, @WebParam(name = "fecha") String fecha, @WebParam(name = "num_captura") String num_captura, @WebParam(name = "peso_captura") int peso_captura) {
//TODO write your implementation code here:
Operaciones op = new Operaciones();
return op.registra_rechazo(SKU,fecha,num_captura,peso_captura);
}
, а затем веб-метод должен что-то вернуть, с void работать не будет