updated SibaManager
This commit is contained in:
parent
55b626ead7
commit
243f419106
@ -37,7 +37,7 @@ import org.slf4j.LoggerFactory;
|
|||||||
public class Siba
|
public class Siba
|
||||||
{
|
{
|
||||||
|
|
||||||
private static final Logger logger = LoggerFactory.getLogger(Siba.class);
|
public static final Logger logger = LoggerFactory.getLogger(Siba.class);
|
||||||
|
|
||||||
public static void main(final String[] args)
|
public static void main(final String[] args)
|
||||||
{
|
{
|
||||||
|
@ -23,6 +23,7 @@ import java.io.File;
|
|||||||
import java.util.ResourceBundle;
|
import java.util.ResourceBundle;
|
||||||
|
|
||||||
import org.apache.commons.lang3.StringUtils;
|
import org.apache.commons.lang3.StringUtils;
|
||||||
|
import org.dclermonte.siba.Siba;
|
||||||
import org.dclermonte.siba.SibaException;
|
import org.dclermonte.siba.SibaException;
|
||||||
import org.dclermonte.siba.model.SibaManager;
|
import org.dclermonte.siba.model.SibaManager;
|
||||||
|
|
||||||
@ -36,6 +37,14 @@ public class SibaCLI
|
|||||||
{
|
{
|
||||||
private static final ResourceBundle BUNDLE = ResourceBundle.getBundle("org.dclermonte.siba.cli.messages"); //$NON-NLS-1$
|
private static final ResourceBundle BUNDLE = ResourceBundle.getBundle("org.dclermonte.siba.cli.messages"); //$NON-NLS-1$
|
||||||
|
|
||||||
|
public static void backup(final File directoryToSave) throws SibaException
|
||||||
|
{
|
||||||
|
File result;
|
||||||
|
result = SibaManager.backup(directoryToSave);
|
||||||
|
System.out.println(BUNDLE.getString("confirmDialog.text") + result.getName()); //$NON-NLS-1$
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
*
|
*
|
||||||
* This method is called for Backup from CLI.
|
* This method is called for Backup from CLI.
|
||||||
@ -123,7 +132,7 @@ public class SibaCLI
|
|||||||
}
|
}
|
||||||
else if (parameterCount == 2)
|
else if (parameterCount == 2)
|
||||||
{
|
{
|
||||||
backup(new File(args[1]), null);
|
backup(new File(args[1]));
|
||||||
}
|
}
|
||||||
else if (parameterCount == 3)
|
else if (parameterCount == 3)
|
||||||
{
|
{
|
||||||
@ -173,10 +182,10 @@ public class SibaCLI
|
|||||||
catch (SibaException sibaException)
|
catch (SibaException sibaException)
|
||||||
{
|
{
|
||||||
System.err.println("SibaException = " + sibaException.getMessage());
|
System.err.println("SibaException = " + sibaException.getMessage());
|
||||||
|
sibaException.printStackTrace();
|
||||||
if (!(sibaException.getCause() == null))
|
if (!(sibaException.getCause() == null))
|
||||||
{
|
{
|
||||||
System.err.println("SibaException chainée = " + sibaException.getCause().getMessage());
|
Siba.logger.info("SibaException chainée = " + sibaException.getCause().getMessage());
|
||||||
}
|
}
|
||||||
help();
|
help();
|
||||||
}
|
}
|
||||||
|
@ -45,6 +45,7 @@ import javax.swing.UIManager;
|
|||||||
import javax.swing.UnsupportedLookAndFeelException;
|
import javax.swing.UnsupportedLookAndFeelException;
|
||||||
|
|
||||||
import org.apache.commons.lang3.StringUtils;
|
import org.apache.commons.lang3.StringUtils;
|
||||||
|
import org.dclermonte.siba.Siba;
|
||||||
import org.dclermonte.siba.SibaException;
|
import org.dclermonte.siba.SibaException;
|
||||||
import org.dclermonte.siba.gui.utils.GUIToolBox;
|
import org.dclermonte.siba.gui.utils.GUIToolBox;
|
||||||
|
|
||||||
@ -256,10 +257,12 @@ public class SibaGUI
|
|||||||
}
|
}
|
||||||
catch (SibaException sibaException)
|
catch (SibaException sibaException)
|
||||||
{
|
{
|
||||||
|
sibaException.printStackTrace();
|
||||||
String dataMissing = sibaException.getMessage();
|
String dataMissing = sibaException.getMessage();
|
||||||
if (!(sibaException.getCause() == null))
|
if (!(sibaException.getCause() == null))
|
||||||
{
|
{
|
||||||
dataMissing.concat(sibaException.getCause().getMessage());
|
Siba.logger.info("SibaException chainée = " + sibaException.getCause().getMessage());
|
||||||
|
// dataMissing.concat(sibaException.getCause().getMessage());
|
||||||
}
|
}
|
||||||
|
|
||||||
String titleWarning = BUNDLE.getString("BackupPanel.TitleWarning.text");
|
String titleWarning = BUNDLE.getString("BackupPanel.TitleWarning.text");
|
||||||
|
@ -20,7 +20,6 @@
|
|||||||
package org.dclermonte.siba.model;
|
package org.dclermonte.siba.model;
|
||||||
|
|
||||||
import java.io.BufferedOutputStream;
|
import java.io.BufferedOutputStream;
|
||||||
import java.io.Closeable;
|
|
||||||
import java.io.File;
|
import java.io.File;
|
||||||
import java.io.FileInputStream;
|
import java.io.FileInputStream;
|
||||||
import java.io.FileOutputStream;
|
import java.io.FileOutputStream;
|
||||||
@ -43,7 +42,7 @@ import org.dclermonte.siba.SibaException;
|
|||||||
|
|
||||||
/**
|
/**
|
||||||
*
|
*
|
||||||
* @author dclermonte
|
* @author Didier Clermonté (dclermonte@april.org)
|
||||||
*
|
*
|
||||||
*/
|
*/
|
||||||
|
|
||||||
@ -51,6 +50,22 @@ public class SibaManager
|
|||||||
{
|
{
|
||||||
private static final ResourceBundle BUNDLE = ResourceBundle.getBundle("org.dclermonte.siba.model.messages"); //$NON-NLS-1$
|
private static final ResourceBundle BUNDLE = ResourceBundle.getBundle("org.dclermonte.siba.model.messages"); //$NON-NLS-1$
|
||||||
|
|
||||||
|
/**
|
||||||
|
* This method perform the backup.
|
||||||
|
*
|
||||||
|
* @param fileToSave
|
||||||
|
* @return
|
||||||
|
* @throws SibaException
|
||||||
|
*/
|
||||||
|
public static File backup(final File fileToSave) throws SibaException
|
||||||
|
{
|
||||||
|
File result;
|
||||||
|
File target = new File(System.getProperty("user.dir"));
|
||||||
|
result = backup(fileToSave, target);
|
||||||
|
//
|
||||||
|
return result;
|
||||||
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* This method perform the backup.
|
* This method perform the backup.
|
||||||
*
|
*
|
||||||
@ -59,58 +74,52 @@ public class SibaManager
|
|||||||
* @return
|
* @return
|
||||||
* @throws SibaException
|
* @throws SibaException
|
||||||
*/
|
*/
|
||||||
public static File backup(final File fileToSave, File target) throws SibaException
|
public static File backup(final File fileToSave, final File target) throws SibaException
|
||||||
{
|
{
|
||||||
File result;
|
File result;
|
||||||
|
TarArchiveOutputStream out = null;
|
||||||
try
|
try
|
||||||
{
|
{
|
||||||
|
|
||||||
if ((fileToSave == null) || !(fileToSave.exists()))
|
if ((fileToSave == null) || !(fileToSave.exists()))
|
||||||
{
|
{
|
||||||
throw new SibaException(BUNDLE.getString("sourceNotExist.text"));
|
throw new SibaException(BUNDLE.getString("sourceNotExist.text"));
|
||||||
}
|
}
|
||||||
|
else if (!(fileToSave.isDirectory()))
|
||||||
|
{
|
||||||
|
throw new SibaException(BUNDLE.getString("NotDirectorySource.text"));
|
||||||
|
}
|
||||||
|
else if (!(target.isDirectory()))
|
||||||
|
{
|
||||||
|
throw new SibaException(BUNDLE.getString("NotDirectoryTarget.text"));
|
||||||
|
}
|
||||||
else
|
else
|
||||||
{
|
{
|
||||||
if (!(fileToSave.isDirectory()))
|
int pathLength = fileToSave.getParentFile().getAbsolutePath().length();
|
||||||
{
|
LocalDateTime date = LocalDateTime.now();
|
||||||
throw new SibaException(BUNDLE.getString("NotDirectorySource.text"));
|
DateTimeFormatter formatter = DateTimeFormatter.ofPattern("yyyy-MM-dd'T'HH'h'mm'mn'ss's'");
|
||||||
}
|
String textDate = date.format(formatter);
|
||||||
else
|
String outputFileNameWithoutExtension = fileToSave.getName() + "-" + textDate;
|
||||||
{
|
result = new File(target + "/" + outputFileNameWithoutExtension + ".tgz");
|
||||||
if ((target == null))
|
OutputStream gzipOutputStream = new GzipCompressorOutputStream(
|
||||||
{
|
new BufferedOutputStream(new FileOutputStream(result)));
|
||||||
target = new File(System.getProperty("user.dir"));
|
out = new TarArchiveOutputStream(gzipOutputStream);
|
||||||
}
|
directoryToSave(fileToSave, out, pathLength);
|
||||||
if (!(target.isDirectory()))
|
out.close();
|
||||||
{
|
fileWithMD5(result, target + "/" + outputFileNameWithoutExtension + ".tgz.md5");
|
||||||
throw new SibaException(BUNDLE.getString("NotDirectoryTarget.text"));
|
|
||||||
}
|
|
||||||
else
|
|
||||||
{
|
|
||||||
int pathLength = fileToSave.getParentFile().getAbsolutePath().length();
|
|
||||||
LocalDateTime date = LocalDateTime.now();
|
|
||||||
DateTimeFormatter formatter = DateTimeFormatter.ofPattern("yyyy-MM-dd'T'HH'h'mm'mn'ss's'");
|
|
||||||
String textDate = date.format(formatter);
|
|
||||||
String outputFileNameWithoutExtension = fileToSave.getName() + "-" + textDate;
|
|
||||||
|
|
||||||
result = new File(target + "/" + outputFileNameWithoutExtension + ".tgz");
|
|
||||||
OutputStream gzipOutputStream = new GzipCompressorOutputStream(
|
|
||||||
new BufferedOutputStream(new FileOutputStream(result)));
|
|
||||||
TarArchiveOutputStream out = new TarArchiveOutputStream(gzipOutputStream);
|
|
||||||
directoryToSave(fileToSave, out, pathLength);
|
|
||||||
out.close();
|
|
||||||
fileCheckMD5(result, target + "/" + outputFileNameWithoutExtension + ".tgz.md5");
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
|
||||||
}
|
}
|
||||||
catch (IOException ioExceptionBackup)
|
catch (IOException ioExceptionBackup)
|
||||||
{
|
{
|
||||||
throw new SibaException(BUNDLE.getString("ioExceptionBackup.text"), ioExceptionBackup); //$NON-NLS-1$
|
throw new SibaException(BUNDLE.getString("ioExceptionBackup.text"), ioExceptionBackup); //$NON-NLS-1$
|
||||||
}
|
}
|
||||||
|
catch (NoSuchAlgorithmException noSuchAlgorithmException)
|
||||||
|
{
|
||||||
|
throw new SibaException(BUNDLE.getString("noSuchAlgorithm.text"), noSuchAlgorithmException); //$NON-NLS-1$
|
||||||
|
}
|
||||||
finally
|
finally
|
||||||
{
|
{
|
||||||
Closeable out = null;
|
|
||||||
IOUtils.closeQuietly(out);
|
IOUtils.closeQuietly(out);
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -128,59 +137,28 @@ public class SibaManager
|
|||||||
public static boolean check(final File choosenFile) throws SibaException
|
public static boolean check(final File choosenFile) throws SibaException
|
||||||
{
|
{
|
||||||
boolean result;
|
boolean result;
|
||||||
|
|
||||||
try
|
try
|
||||||
{
|
{
|
||||||
if (choosenFile.exists() && (choosenFile.length() > 32))
|
String md5String = loadMD5Sum(choosenFile);
|
||||||
|
File fileToCheck1 = loadFileToCheck(choosenFile);
|
||||||
|
if (StringUtils.equals(md5String, md5(fileToCheck1)))
|
||||||
{
|
{
|
||||||
FileReader fileReader = new FileReader(choosenFile);
|
result = true;
|
||||||
char[] md5 = new char[32];
|
|
||||||
byte[] md5byte = new byte[32];
|
|
||||||
char[] fileToCheck = new char[(int) (choosenFile.length()) - 32];
|
|
||||||
String md5String = new String();
|
|
||||||
for (int index = 0; index < 32; index++)
|
|
||||||
{
|
|
||||||
md5[index] = (char) fileReader.read();
|
|
||||||
md5byte[index] = (byte) md5[index];
|
|
||||||
md5String = md5String + md5[index];
|
|
||||||
}
|
|
||||||
fileReader.read();
|
|
||||||
String fileNameToString = new String();
|
|
||||||
for (int index = 36; index < (choosenFile.length() + 2); index++)
|
|
||||||
{
|
|
||||||
fileToCheck[index - 36] = (char) fileReader.read();
|
|
||||||
fileNameToString = fileNameToString + fileToCheck[index - 36];
|
|
||||||
}
|
|
||||||
|
|
||||||
fileReader.close();
|
|
||||||
File fileToCheck1;
|
|
||||||
if (choosenFile.isAbsolute())
|
|
||||||
{
|
|
||||||
fileToCheck1 = new File(choosenFile.getParent() + "/" + fileNameToString);
|
|
||||||
}
|
|
||||||
else
|
|
||||||
{
|
|
||||||
String path = System.getProperty("user.dir");
|
|
||||||
fileToCheck1 = new File(path + "/" + fileNameToString);
|
|
||||||
}
|
|
||||||
|
|
||||||
if (StringUtils.equals(md5String, md5(fileToCheck1)))
|
|
||||||
{
|
|
||||||
result = true;
|
|
||||||
}
|
|
||||||
else
|
|
||||||
{
|
|
||||||
result = false;
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
else
|
else
|
||||||
{
|
{
|
||||||
throw new SibaException(BUNDLE.getString("NotExistFileToCheck.text"));
|
result = false;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
catch (IOException ioExceptionCheck)
|
catch (IOException ioExceptionCheck)
|
||||||
{
|
{
|
||||||
throw new SibaException(BUNDLE.getString("ioExceptionCheck.text"), ioExceptionCheck); //$NON-NLS-1$
|
throw new SibaException(BUNDLE.getString("ioExceptionCheck.text"), ioExceptionCheck); //$NON-NLS-1$
|
||||||
}
|
}
|
||||||
|
catch (NoSuchAlgorithmException noSuchAlgorithmException)
|
||||||
|
{
|
||||||
|
throw new SibaException(BUNDLE.getString("noSuchAlgorithm.text"), noSuchAlgorithmException); //$NON-NLS-1$
|
||||||
|
}
|
||||||
//
|
//
|
||||||
return result;
|
return result;
|
||||||
}
|
}
|
||||||
@ -192,47 +170,40 @@ public class SibaManager
|
|||||||
* @param directory
|
* @param directory
|
||||||
* @param outputStream
|
* @param outputStream
|
||||||
* @param pathLength
|
* @param pathLength
|
||||||
* @throws SibaException
|
* @throws IOException
|
||||||
*/
|
*/
|
||||||
public static void directoryToSave(final File directory, final TarArchiveOutputStream outputStream,
|
public static void directoryToSave(final File directory, final TarArchiveOutputStream outputStream,
|
||||||
final int pathLength) throws SibaException
|
final int pathLength) throws IOException
|
||||||
{
|
{
|
||||||
try
|
for (File file : directory.listFiles())
|
||||||
{
|
{
|
||||||
for (File file : directory.listFiles())
|
|
||||||
|
if (file.isDirectory())
|
||||||
{
|
{
|
||||||
|
if (file.listFiles().length == 0)
|
||||||
if (file.isDirectory())
|
|
||||||
{
|
|
||||||
if (file.listFiles().length == 0)
|
|
||||||
{
|
|
||||||
TarArchiveEntry tarArchiveEntry = new TarArchiveEntry(file);
|
|
||||||
String pathPartiel = file.getPath().substring(pathLength);
|
|
||||||
tarArchiveEntry.setName(pathPartiel);
|
|
||||||
outputStream.putArchiveEntry(tarArchiveEntry);
|
|
||||||
outputStream.closeArchiveEntry();
|
|
||||||
}
|
|
||||||
else
|
|
||||||
{
|
|
||||||
directoryToSave(file, outputStream, pathLength);
|
|
||||||
}
|
|
||||||
|
|
||||||
}
|
|
||||||
else
|
|
||||||
{
|
{
|
||||||
TarArchiveEntry tarArchiveEntry = new TarArchiveEntry(file);
|
TarArchiveEntry tarArchiveEntry = new TarArchiveEntry(file);
|
||||||
String pathPartiel = file.getPath().substring(pathLength);
|
String pathPartiel = file.getPath().substring(pathLength);
|
||||||
tarArchiveEntry.setName(pathPartiel);
|
tarArchiveEntry.setName(pathPartiel);
|
||||||
outputStream.putArchiveEntry(tarArchiveEntry);
|
outputStream.putArchiveEntry(tarArchiveEntry);
|
||||||
IOUtils.copy(new FileInputStream(file), outputStream);
|
|
||||||
outputStream.closeArchiveEntry();
|
outputStream.closeArchiveEntry();
|
||||||
|
|
||||||
}
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
directoryToSave(file, outputStream, pathLength);
|
||||||
|
}
|
||||||
|
|
||||||
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
TarArchiveEntry tarArchiveEntry = new TarArchiveEntry(file);
|
||||||
|
String pathPartiel = file.getPath().substring(pathLength);
|
||||||
|
tarArchiveEntry.setName(pathPartiel);
|
||||||
|
outputStream.putArchiveEntry(tarArchiveEntry);
|
||||||
|
IOUtils.copy(new FileInputStream(file), outputStream);
|
||||||
|
outputStream.closeArchiveEntry();
|
||||||
|
|
||||||
}
|
}
|
||||||
}
|
|
||||||
catch (IOException ioExceptionTarEntry)
|
|
||||||
{
|
|
||||||
throw new SibaException(BUNDLE.getString("ioExceptionTarEntry.text"), ioExceptionTarEntry); //$NON-NLS-1$
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -243,24 +214,88 @@ public class SibaManager
|
|||||||
* @param directoryToSave
|
* @param directoryToSave
|
||||||
* @param destination
|
* @param destination
|
||||||
* @return
|
* @return
|
||||||
* @throws SibaException
|
* @throws IOException
|
||||||
|
* @throws NoSuchAlgorithmException
|
||||||
*/
|
*/
|
||||||
public static File fileCheckMD5(final File directoryToSave, final String destination) throws SibaException
|
public static File fileWithMD5(final File directoryToSave, final String destination)
|
||||||
|
throws IOException, NoSuchAlgorithmException
|
||||||
{
|
{
|
||||||
File result;
|
File result;
|
||||||
try
|
|
||||||
|
result = new File(destination);
|
||||||
|
FileWriter fileWriter = new FileWriter(result);
|
||||||
|
fileWriter.write(md5(directoryToSave));
|
||||||
|
String newLine = System.getProperty("line.separator");
|
||||||
|
fileWriter.append(" " + directoryToSave.getName() + newLine);
|
||||||
|
fileWriter.close();
|
||||||
|
|
||||||
|
//
|
||||||
|
return result;
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
*
|
||||||
|
* @param choosenFile
|
||||||
|
* @return
|
||||||
|
* @throws IOException
|
||||||
|
*/
|
||||||
|
public static File loadFileToCheck(final File choosenFile) throws IOException
|
||||||
|
{
|
||||||
|
File result = null;
|
||||||
|
if (choosenFile.exists() && (choosenFile.length() > 32))
|
||||||
{
|
{
|
||||||
result = new File(destination);
|
FileReader fileReader = new FileReader(choosenFile);
|
||||||
FileWriter fileWriter = new FileWriter(result);
|
|
||||||
fileWriter.write(md5(directoryToSave));
|
char[] fileToCheck = new char[(int) (choosenFile.length()) - 32];
|
||||||
String newLine = System.getProperty("line.separator");
|
fileReader.read();
|
||||||
fileWriter.append(" " + directoryToSave.getName() + newLine);
|
fileReader.skip(32);
|
||||||
fileWriter.close();
|
String fileNameToString = new String();
|
||||||
|
for (int index = 36; index < (choosenFile.length() + 2); index++)
|
||||||
|
{
|
||||||
|
fileToCheck[index - 36] = (char) fileReader.read();
|
||||||
|
fileNameToString = fileNameToString + fileToCheck[index - 36];
|
||||||
|
}
|
||||||
|
|
||||||
|
fileReader.close();
|
||||||
|
if (choosenFile.isAbsolute())
|
||||||
|
{
|
||||||
|
result = new File(choosenFile.getParent() + "/" + fileNameToString);
|
||||||
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
String path = System.getProperty("user.dir");
|
||||||
|
result = new File(path + "/" + fileNameToString);
|
||||||
|
}
|
||||||
}
|
}
|
||||||
catch (IOException ioExceptionFileMD5)
|
//
|
||||||
|
return result;
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
*
|
||||||
|
* @param choosenFile
|
||||||
|
* @return
|
||||||
|
* @throws IOException
|
||||||
|
*/
|
||||||
|
public static String loadMD5Sum(final File choosenFile) throws IOException
|
||||||
|
{
|
||||||
|
String result = "";
|
||||||
|
|
||||||
|
if (choosenFile.exists() && (choosenFile.length() > 32))
|
||||||
{
|
{
|
||||||
throw new SibaException(BUNDLE.getString("ioExceptionFileMD5.text"), ioExceptionFileMD5); //$NON-NLS-1$
|
FileReader fileReader = new FileReader(choosenFile);
|
||||||
|
char[] md5 = new char[32];
|
||||||
|
byte[] md5byte = new byte[32];
|
||||||
|
for (int index = 0; index < 32; index++)
|
||||||
|
{
|
||||||
|
md5[index] = (char) fileReader.read();
|
||||||
|
md5byte[index] = (byte) md5[index];
|
||||||
|
result = result + md5[index];
|
||||||
|
}
|
||||||
|
fileReader.close();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
//
|
||||||
//
|
//
|
||||||
return result;
|
return result;
|
||||||
}
|
}
|
||||||
@ -270,47 +305,39 @@ public class SibaManager
|
|||||||
*
|
*
|
||||||
* @param input
|
* @param input
|
||||||
* @return
|
* @return
|
||||||
* @throws SibaException
|
* @throws IOException
|
||||||
|
* @throws NoSuchAlgorithmException
|
||||||
*/
|
*/
|
||||||
public static String md5(final File input) throws SibaException
|
public static String md5(final File input) throws IOException, NoSuchAlgorithmException
|
||||||
{
|
{
|
||||||
String result;
|
String result;
|
||||||
StringBuilder hashString = new StringBuilder();
|
StringBuilder hashString = new StringBuilder();
|
||||||
try
|
|
||||||
{
|
|
||||||
byte[] byteInput = new byte[(int) input.length()];
|
|
||||||
FileInputStream fileInputStream = new FileInputStream(input);
|
|
||||||
for (int index1 = 0; index1 < input.length(); index1++)
|
|
||||||
{
|
|
||||||
byteInput[index1] = (byte) fileInputStream.read();
|
|
||||||
}
|
|
||||||
byte[] hash = null;
|
|
||||||
MessageDigest messageDigest = MessageDigest.getInstance("MD5");
|
|
||||||
hash = messageDigest.digest(byteInput);
|
|
||||||
|
|
||||||
for (int index = 0; index < hash.length; index++)
|
byte[] byteInput = new byte[(int) input.length()];
|
||||||
|
FileInputStream fileInputStream = new FileInputStream(input);
|
||||||
|
for (int index1 = 0; index1 < input.length(); index1++)
|
||||||
|
{
|
||||||
|
byteInput[index1] = (byte) fileInputStream.read();
|
||||||
|
}
|
||||||
|
byte[] hash = null;
|
||||||
|
MessageDigest messageDigest = MessageDigest.getInstance("MD5");
|
||||||
|
hash = messageDigest.digest(byteInput);
|
||||||
|
|
||||||
|
for (int index = 0; index < hash.length; index++)
|
||||||
|
{
|
||||||
|
String hex = Integer.toHexString(hash[index]);
|
||||||
|
if (hex.length() == 1)
|
||||||
{
|
{
|
||||||
String hex = Integer.toHexString(hash[index]);
|
hashString.append('0');
|
||||||
if (hex.length() == 1)
|
hashString.append(hex.charAt(hex.length() - 1));
|
||||||
{
|
}
|
||||||
hashString.append('0');
|
else
|
||||||
hashString.append(hex.charAt(hex.length() - 1));
|
{
|
||||||
}
|
hashString.append(hex.substring(hex.length() - 2));
|
||||||
else
|
|
||||||
{
|
|
||||||
hashString.append(hex.substring(hex.length() - 2));
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
fileInputStream.close();
|
|
||||||
}
|
|
||||||
catch (NoSuchAlgorithmException noSuchAlgorithmException)
|
|
||||||
{
|
|
||||||
throw new SibaException(BUNDLE.getString("noSuchAlgorithm.text"), noSuchAlgorithmException); //$NON-NLS-1$
|
|
||||||
}
|
|
||||||
catch (IOException ioException)
|
|
||||||
{
|
|
||||||
throw new SibaException(BUNDLE.getString("ioExceptionMD5.text"), ioException); //$NON-NLS-1$
|
|
||||||
}
|
}
|
||||||
|
fileInputStream.close();
|
||||||
|
|
||||||
result = hashString.toString();
|
result = hashString.toString();
|
||||||
//
|
//
|
||||||
return result;
|
return result;
|
||||||
|
Loading…
x
Reference in New Issue
Block a user