Java tutorial
package br.com.itfox.utils; import br.com.itfox.business.DBase; import br.com.itfox.config.Preferences; import br.com.itfox.servlet.DashboardServlet; import java.awt.image.BufferedImage; import java.io.UnsupportedEncodingException; import java.math.BigDecimal; import java.math.RoundingMode; import java.net.URLEncoder; import java.sql.Blob; import java.sql.Connection; import java.sql.SQLException; import java.sql.Timestamp; import java.text.DecimalFormat; import java.text.ParseException; import java.text.SimpleDateFormat; import java.util.Calendar; import java.util.Date; import java.util.Locale; import java.util.logging.Level; import java.util.logging.Logger; import javax.swing.JFormattedTextField; import javax.swing.text.MaskFormatter; import org.apache.commons.lang3.time.DateUtils; //import org.apache.commons.lang.time.DateUtils; import java.io.ByteArrayInputStream; import java.io.File; import java.io.IOException; import javax.imageio.ImageIO; import sun.misc.BASE64Decoder; /* * To change this license header, choose License Headers in Project Properties. * To change this template file, choose Tools | Templates * and open the template in the editor. */ /** * * @author belchiorpalma */ public class Utils { public static String dateFormat(String date_s) { String dateFormated = ""; try { //String date_s = "2011-01-18 00:00:00.0"; // *** note that it's "yyyy-MM-dd hh:mm:ss" not "yyyy-mm-dd hh:mm:ss" SimpleDateFormat dt = new SimpleDateFormat("dd/MM/yy"); Date date = dt.parse(date_s); // *** same for the format String below SimpleDateFormat dt1 = new SimpleDateFormat("yyyy-MM-dd"); dateFormated = dt1.format(date); //System.out.println(dateFormated); } catch (ParseException ex) { Logger.getLogger(Utils.class.getName()).log(Level.SEVERE, null, ex); } return dateFormated; } public static Date dateFormatStringToDate(String date_s) { String dateFormated = ""; Date date = new Date(); try { //String date_s = "2011-01-18 00:00:00.0"; // *** note that it's "yyyy-MM-dd hh:mm:ss" not "yyyy-mm-dd hh:mm:ss" SimpleDateFormat dt = new SimpleDateFormat("dd/MM/yy"); date = dt.parse(date_s); // *** same for the format String below //SimpleDateFormat dt1 = new SimpleDateFormat("yyyy-MM-dd"); //dateFormated=dt1.format(date); //System.out.println(dateFormated); } catch (ParseException ex) { Logger.getLogger(Utils.class.getName()).log(Level.SEVERE, null, ex); } return date; } public static Timestamp dateToTimestamp(Date utilDate) { long millis = DateUtils.truncate(utilDate, Calendar.MILLISECOND).getTime(); java.sql.Timestamp sq = new java.sql.Timestamp(millis); return sq; } public static String dateFormatPt(String date_s) { String dateFormated = ""; try { //String date_s = "2011-01-18 00:00:00.0"; // *** note that it's "yyyy-MM-dd hh:mm:ss" not "yyyy-mm-dd hh:mm:ss" SimpleDateFormat dt = new SimpleDateFormat("yyyy-MM-dd"); Date date = dt.parse(date_s); // *** same for the format String below SimpleDateFormat dt1 = new SimpleDateFormat("dd/MM/yy"); dateFormated = dt1.format(date); //System.out.println(dateFormated); } catch (ParseException ex) { Logger.getLogger(Utils.class.getName()).log(Level.SEVERE, null, ex); } return dateFormated; } public static String dateFormatPt2(String date_s) { String dateFormated = ""; try { //String date_s = "2011-01-18 00:00:00.0"; // *** note that it's "yyyy-MM-dd hh:mm:ss" not "yyyy-mm-dd hh:mm:ss" SimpleDateFormat dt = new SimpleDateFormat("yyyy-MM-dd hh:mm:ss"); Date date = dt.parse(date_s); // *** same for the format String below SimpleDateFormat dt1 = new SimpleDateFormat("dd/MM/yy"); dateFormated = dt1.format(date); //System.out.println(dateFormated); } catch (ParseException ex) { Logger.getLogger(Utils.class.getName()).log(Level.SEVERE, null, ex); } return dateFormated; } public static String dateFormat_dd_MM_yyyy(String date_s) { String dateFormated = ""; try { //String date_s = "2011-01-18 00:00:00.0"; // *** note that it's "yyyy-MM-dd hh:mm:ss" not "yyyy-mm-dd hh:mm:ss" SimpleDateFormat dt = new SimpleDateFormat("yyyy-MM-dd"); Date date = dt.parse(date_s); // *** same for the format String below SimpleDateFormat dt1 = new SimpleDateFormat("dd/MM/yyyy"); dateFormated = dt1.format(date); //System.out.println(dateFormated); } catch (ParseException ex) { Logger.getLogger(Utils.class.getName()).log(Level.SEVERE, null, ex); } return dateFormated; } public static String toHexString(byte[] ba) { StringBuilder str = new StringBuilder(); for (int i = 0; i < ba.length; i++) str.append(String.format("%x", ba[i])); return str.toString(); } public static String fromHexString(String hex) { StringBuilder str = new StringBuilder(); for (int i = 0; i < hex.length(); i += 2) { str.append((char) Integer.parseInt(hex.substring(i, i + 2), 16)); } return str.toString(); } public static String formatCpfCnpj(String value) { String maskCpf = "###.###.###-##"; String maskCnpj = "##.###.###/####-##"; String maskCep = "##.###-###"; String mask = ""; if (value == null) { return ""; } if (value.length() == 14) { mask = maskCnpj; } else if (value.length() == 11) { mask = maskCpf; } else if (value.length() == 8) { mask = maskCep; } try { MaskFormatter formatter = new MaskFormatter(mask); JFormattedTextField textField = new JFormattedTextField(); formatter.install(textField); textField.setText(value); value = textField.getText(); } catch (Exception e) { e.printStackTrace(); } return value; } public static String formatTelephone(String value) { String maskTel = "####-####"; String maskCel = "#####-####"; String maskDDD = "(##) "; String mask = ""; if (value == null) { return ""; } if (value.length() == 9) { mask = maskCel; } else if (value.length() == 8) { mask = maskTel; } else if (value.length() == 2) { mask = maskDDD; } try { MaskFormatter formatter = new MaskFormatter(mask); JFormattedTextField textField = new JFormattedTextField(); formatter.install(textField); textField.setText(value); value = textField.getText(); } catch (Exception e) { e.printStackTrace(); } return value; } public static String formatDecimal(BigDecimal val) { String s = ""; try { DecimalFormat df = (DecimalFormat) DecimalFormat.getInstance(new Locale("en", "EN")); df.setMaximumFractionDigits(Preferences.MAXIMUM_FRACTION_DIGITS); df.setMinimumFractionDigits(Preferences.MINIMUM_FRACTION_DIGITS); df.setMinimumIntegerDigits(Preferences.MIMIMUM_INTEGER_DIGITS); df.setRoundingMode(Preferences.ROUNDING_MODE); s = String.valueOf(df.format(val)); } catch (Exception ex) { br.com.itfox.utils.Logger.getLogger(ex, Utils.class.getName() + "***" + val + "***", ex.getMessage()); } return s; } public static String formatDecimal(float val) { String s = ""; if (val > 0) { try { DecimalFormat df = (DecimalFormat) DecimalFormat.getInstance(new Locale("en", "EN")); df.setMaximumFractionDigits(Preferences.MAXIMUM_FRACTION_DIGITS); df.setMinimumFractionDigits(Preferences.MINIMUM_FRACTION_DIGITS); df.setMinimumIntegerDigits(Preferences.MIMIMUM_INTEGER_DIGITS); df.setRoundingMode(Preferences.ROUNDING_MODE); s = String.valueOf(df.format(val)); } catch (Exception ex) { br.com.itfox.utils.Logger.getLogger(ex, Utils.class.getName() + "***" + val + "***", ex.getMessage()); } } return s; } public static String formatDecimal(double val) { String s = ""; if (val > 0) { try { DecimalFormat df = (DecimalFormat) DecimalFormat.getInstance(new Locale("en", "EN")); df.setMaximumFractionDigits(Preferences.MAXIMUM_FRACTION_DIGITS); df.setMinimumFractionDigits(Preferences.MINIMUM_FRACTION_DIGITS); df.setMinimumIntegerDigits(Preferences.MIMIMUM_INTEGER_DIGITS); df.setRoundingMode(Preferences.ROUNDING_MODE); s = String.valueOf(df.format(val)); } catch (Exception ex) { br.com.itfox.utils.Logger.getLogger(ex, Utils.class.getName() + "***" + val + "***", ex.getMessage()); } } return s; } public static String encodeURIComponent(String url) { String result = ""; try { result = URLEncoder.encode(url, "UTF-8").replaceAll("\\+", "%20").replaceAll("\\%21", "!") .replaceAll("\\%27", "'").replaceAll("\\%28", "(").replaceAll("\\%29", ")") .replaceAll("\\%7E", "~"); //the slow option: //new ScriptEngineManager().getEngineByName("JavaScript")...etc } catch (UnsupportedEncodingException e) { //never e.printStackTrace(); } return result; } public static String encodeURI(String url) { return encodeURIComponent(url).replaceAll("%3A", ":").replaceAll("%2F", "/").replaceAll("%3F", "?") .replaceAll("%3D", "=").replaceAll("%26", "&"); } public static Blob stringToBlob(String s) { try { if (s != null && !s.isEmpty() && s != "") { Connection conn = new DBase(true).getConnection(); Blob myBlob = conn.createBlob(); myBlob.setBytes(1, s.getBytes()); conn.close(); return myBlob; } } catch (SQLException ex) { Logger.getLogger(Utils.class.getName()).log(Level.SEVERE, null, ex); } return null; } public static String blobToString(Blob blob) { try { if (blob != null) { byte[] bdata = blob.getBytes(1, (int) blob.length()); String text = new String(bdata); text = text.replaceAll("\r\n", "<br>"); return text; } } catch (SQLException ex) { Logger.getLogger(Utils.class.getName()).log(Level.SEVERE, null, ex); } return ""; } public void convertBase64StringToImage(String sourceData, String filename) { try { //String sourceData = ""; // tokenize the data if (sourceData != null && sourceData.length() > 1) { String[] parts = sourceData.split(","); String imageString = parts[1]; // create a buffered image BufferedImage image = null; byte[] imageByte; BASE64Decoder decoder = new BASE64Decoder(); imageByte = decoder.decodeBuffer(imageString); ByteArrayInputStream bis = new ByteArrayInputStream(imageByte); image = ImageIO.read(bis); bis.close(); // write the image to a file File outputfile = new File(filename); ImageIO.write(image, "jpg", outputfile); } } catch (IOException ex) { Logger.getLogger(Utils.class.getName()).log(Level.SEVERE, null, ex); } } public static int parseInt(String s) { int i = 0; try { if (s != null && !s.isEmpty() && s != "" && s != " " && s.length() > 0 && !s.equalsIgnoreCase("null") && !s.equalsIgnoreCase("undefined")) { i = Integer.parseInt(s); } } catch (Exception ex) { br.com.itfox.utils.Logger.getLogger(ex, DashboardServlet.class.getName() + " -- Parse Int Exception", ex.getMessage()); Logger.getLogger(DashboardServlet.class.getName()).log(Level.SEVERE, null, ex); } return i; } public static float parseFloat(String s) { float i = 0; try { if (s != null && !s.isEmpty() && s != "" && s != " " && !s.trim().equalsIgnoreCase("-") && s.length() > 0) { i = Float.parseFloat(s); } else if (s != null && s.trim().equalsIgnoreCase("-")) { i = 0; } } catch (Exception ex) { br.com.itfox.utils.Logger.getLogger(ex, DashboardServlet.class.getName() + " -- Parse Float Exception", ex.getMessage()); Logger.getLogger(DashboardServlet.class.getName()).log(Level.SEVERE, null, ex); } return i; } }