📄 columnencryption.java
字号:
/******************************************************************************
* The contents of this file are subject to the Compiere License Version 1.1
* ("License"); You may not use this file except in compliance with the License
* You may obtain a copy of the License at http://www.compiere.org/license.html
* Software distributed under the License is distributed on an "AS IS" basis,
* WITHOUT WARRANTY OF ANY KIND, either express or implied. See the License for
* the specific language governing rights and limitations under the License.
* The Original Code is Compiere ERP & CRM Smart Business Solution. The Initial
* Developer of the Original Code is Jorg Janke. Portions created by Jorg Janke
* are Copyright (C) 1999-2005 Jorg Janke.
* All parts are Copyright (C) 1999-2005 ComPiere, Inc. All Rights Reserved.
* Contributor(s): ______________________________________.
*****************************************************************************/
package org.compiere.process;
import java.util.logging.*;
import org.compiere.model.*;
import org.compiere.util.*;
/**
* Column Encryption Test
*
* @author Jorg Janke
* @version $Id: ColumnEncryption.java,v 1.3 2005/09/29 22:01:55 jjanke Exp $
*/
public class ColumnEncryption extends SvrProcess
{
/** Enable/Disable Encryption */
private boolean p_IsEncrypted = false;
/** Change Encryption Settings */
private boolean p_ChangeSetting = false;
/** Maximum Length */
private int p_MaxLength = 0;
/** Test Value */
private String p_TestValue = null;
/** The Column */
private int p_AD_Column_ID = 0;
/**
* Prepare - e.g., get Parameters.
*/
protected void prepare()
{
ProcessInfoParameter[] para = getParameter();
for (int i = 0; i < para.length; i++)
{
String name = para[i].getParameterName();
if (para[i].getParameter() == null)
;
else if (name.equals("IsEncrypted"))
p_IsEncrypted = "Y".equals(para[i].getParameter());
else if (name.equals("ChangeSetting"))
p_ChangeSetting = "Y".equals(para[i].getParameter());
else if (name.equals("MaxLength"))
p_MaxLength = para[i].getParameterAsInt();
else if (name.equals("TestValue"))
p_TestValue = (String)para[i].getParameter();
else
log.log(Level.SEVERE, "Unknown Parameter: " + name);
}
p_AD_Column_ID = getRecord_ID();
} // prepare
/**
* Process
* @return info
* @throws Exception
*/
protected String doIt () throws Exception
{
log.info("AD_Column_ID=" + p_AD_Column_ID
+ ", IsEncrypted=" + p_IsEncrypted
+ ", ChangeSetting=" + p_ChangeSetting
+ ", MaxLength=" + p_MaxLength);
M_Column column = new M_Column (getCtx(), p_AD_Column_ID, null);
if (column.get_ID() == 0 || column.get_ID() != p_AD_Column_ID)
throw new CompiereUserError("@NotFound@ @AD_Column_ID@ - " + p_AD_Column_ID);
//
String columnName = column.getColumnName();
int dt = column.getAD_Reference_ID();
// Can it be enabled?
if (column.isKey()
|| column.isParent()
|| column.isStandardColumn()
|| column.isVirtualColumn()
|| column.isIdentifier()
|| column.isTranslated()
|| DisplayType.isLookup(dt)
|| DisplayType.isLOB(dt)
|| "DocumentNo".equalsIgnoreCase(column.getColumnName())
|| "Value".equalsIgnoreCase(column.getColumnName())
|| "Name".equalsIgnoreCase(column.getColumnName()))
{
if (column.isEncrypted())
{
column.setIsEncrypted(false);
column.save();
}
return columnName + ": cannot be encrypted";
}
// Start
addLog(0, null, null, "Encryption Class = " + SecureEngine.getClassName());
boolean error = false;
// Test Value
if (p_TestValue != null && p_TestValue.length() > 0)
{
String encString = SecureEngine.encrypt(p_TestValue);
addLog(0, null, null, "Encrypted Test Value=" + encString);
String clearString = SecureEngine.decrypt(encString);
if (p_TestValue.equals(clearString))
addLog(0, null, null, "Decrypted=" + clearString
+ " (same as test value)");
else
{
addLog(0, null, null, "Decrypted=" + clearString
+ " (NOT the same as test value - check algorithm)");
error = true;
}
int encLength = encString.length();
addLog(0, null, null, "Test Length=" + p_TestValue.length() + " -> " + encLength);
if (encLength <= column.getFieldLength())
addLog(0, null, null, "Encrypted Length (" + encLength
+ ") fits into field (" + column.getFieldLength() + ")");
else
{
addLog(0, null, null, "Encrypted Length (" + encLength
+ ") does NOT fit into field (" + column.getFieldLength() + ") - resize field");
error = true;
}
}
// Length Test
if (p_MaxLength != 0)
{
String testClear = "1234567890abcdefghijklmnopqrstuvwxyzABCDEFGHIJKLMNOPQRSTUVWXYZ";
while (testClear.length() < p_MaxLength)
testClear += testClear;
testClear = testClear.substring(0, p_MaxLength);
log.config("Test=" + testClear + " (" + p_MaxLength + ")");
//
String encString = SecureEngine.encrypt(testClear);
int encLength = encString.length();
addLog(0, null, null, "Test Max Length=" + testClear.length() + " -> " + encLength);
if (encLength <= column.getFieldLength())
addLog(0, null, null, "Encrypted Max Length (" + encLength
+ ") fits into field (" + column.getFieldLength() + ")");
else
{
addLog(0, null, null, "Encrypted Max Length (" + encLength
+ ") does NOT fit into field (" + column.getFieldLength() + ") - resize field");
error = true;
}
}
if (p_IsEncrypted != column.isEncrypted())
{
if (error || !p_ChangeSetting)
addLog(0, null, null, "Encryption NOT changed - Encryption=" + column.isEncrypted());
else
{
column.setIsEncrypted(p_IsEncrypted);
if (column.save())
addLog(0, null, null, "Encryption CHANGED - Encryption=" + column.isEncrypted());
else
addLog(0, null, null, "Save Error");
}
}
return "Encryption=" + column.isEncrypted();
} // doIt
} // EncryptionTest
⌨️ 快捷键说明
复制代码
Ctrl + C
搜索代码
Ctrl + F
全屏模式
F11
切换主题
Ctrl + Shift + D
显示快捷键
?
增大字号
Ctrl + =
减小字号
Ctrl + -