⭐ 欢迎来到虫虫下载站! | 📦 资源下载 📁 资源专辑 ℹ️ 关于我们
⭐ 虫虫下载站

📄 memberinfoobfuscator.java

📁 proguard 3.5 java 混淆器 最新 免费 好用的 大家用用试一下吧 天行健-君子以自强不息 地势坤-君子以厚德载物
💻 JAVA
字号:
/* $Id: MemberInfoObfuscator.java,v 1.14.2.1 2006/01/16 22:57:56 eric Exp $ * * ProGuard -- shrinking, optimization, and obfuscation of Java class files. * * Copyright (c) 2002-2006 Eric Lafortune (eric@graphics.cornell.edu) * * This program is free software; you can redistribute it and/or modify it * under the terms of the GNU General Public License as published by the Free * Software Foundation; either version 2 of the License, or (at your option) * any later version. * * This program is distributed in the hope that it will be useful, but WITHOUT * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or * FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License for * more details. * * You should have received a copy of the GNU General Public License along * with this program; if not, write to the Free Software Foundation, Inc., * 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA */package proguard.obfuscate;import proguard.classfile.*;import proguard.classfile.util.MethodInfoLinker;import proguard.classfile.visitor.MemberInfoVisitor;import java.util.*;/** * This MemberInfoVisitor obfuscates all class members that it visits. * It uses names from the given name factory. At the same time, it avoids names * from the given descriptor map. * The class members must have been linked before applying this visitor. * * @see MethodInfoLinker * * @author Eric Lafortune */public class MemberInfoObfuscator implements MemberInfoVisitor{    private boolean     allowAggressiveOverloading;    private NameFactory nameFactory;    private Map         descriptorMap;    /**     * Creates a new MemberInfoObfuscator.     * @param allowAggressiveOverloading a flag that specifies whether class     *                                   members can be overloaded aggressively.     * @param nameFactory                the factory that can produce     *                                   obfuscated member names.     * @param descriptorMap              the map of names to avoid:     *                                   [member descriptor - new name - old name].     */    public MemberInfoObfuscator(boolean     allowAggressiveOverloading,                                NameFactory nameFactory,                                Map         descriptorMap)    {        this.allowAggressiveOverloading = allowAggressiveOverloading;        this.nameFactory                = nameFactory;        this.descriptorMap              = descriptorMap;    }    // Implementations for MemberInfoVisitor.    public void visitProgramFieldInfo(ProgramClassFile programClassFile, ProgramFieldInfo programFieldInfo)    {        visitMemberInfo(programClassFile, programFieldInfo);    }    public void visitProgramMethodInfo(ProgramClassFile programClassFile, ProgramMethodInfo programMethodInfo)    {        // Special cases: <clinit> and <init> are always kept unchanged.        // We can ignore them here.        String name = programMethodInfo.getName(programClassFile);        if (name.equals(ClassConstants.INTERNAL_METHOD_NAME_CLINIT) ||            name.equals(ClassConstants.INTERNAL_METHOD_NAME_INIT))        {            return;        }        visitMemberInfo(programClassFile, programMethodInfo);    }    public void visitLibraryFieldInfo(LibraryClassFile libraryClassFile, LibraryFieldInfo libraryFieldInfo) {}    public void visitLibraryMethodInfo(LibraryClassFile libraryClassFile, LibraryMethodInfo libraryMethodInfo) {}    /**     * Inserts the given class member into the main map.     * @param classFile  the class file of the given member.     * @param memberInfo the class member to be linked.     */    private void visitMemberInfo(ClassFile classFile, MemberInfo memberInfo)    {        // Get the member's name and descriptor.        String name       = memberInfo.getName(classFile);        String descriptor = memberInfo.getDescriptor(classFile);        // Check whether we're allowed to do aggressive overloading        if (!allowAggressiveOverloading)        {            // Trim the return argument from the descriptor if not.            // Works for fields and methods alike.            descriptor = descriptor.substring(0, descriptor.indexOf(')')+1);        }        // Put the [descriptor - new name] in the map,        // creating a new [new name - old name] map if necessary.        Map newNameMap = retrieveNameMap(descriptorMap, descriptor);        // Get the member's new name.        String newName = newMemberName(memberInfo);        // Assign a new one, if necessary.        if (newName == null)        {            // Find an acceptable new name.            nameFactory.reset();            do            {                newName = nameFactory.nextName();            }            while (newNameMap.containsKey(newName));            // Assign the new name.            setNewMemberName(memberInfo, newName);            // Remember not to use the new name again in this name space.            newNameMap.put(newName, name);        }        else if (!name.equals(newNameMap.get(newName)))        {            // TODO: Preferentially keep the library method's name.            // TODO: Detect conflicting library member names.            // There's a conflict! A member (with a given old name) in a            // first namespace has received the same new name as this            // member (with a different old name) in a second name space,            // and now these two have to live together in this name space.            // Mark the name as conflicting.            MemberInfoNameConflictFilter.markConflictingName(memberInfo);        }    }    // Small utility methods.    /**     * Gets the [new name - old name] map, based on the given map     * [descriptor - new name - old name] and a given descriptor.     * A new empty map is created if necessary.     * @param descriptorMap the map of descriptors to [new name - old name] maps.     * @param descriptor    the class member descriptor.     * @return the corresponding [new name - old name] map.     */    static Map retrieveNameMap(Map descriptorMap, String descriptor)    {        // See if we can find the nested map with this descriptor key.        Map nameMap = (Map)descriptorMap.get(descriptor);        // Create a new one if not.        if (nameMap == null)        {            nameMap = new HashMap();            descriptorMap.put(descriptor, nameMap);        }        return nameMap;    }    /**     * Assigns a fixed new name to the given class member.     * @param memberInfo the class member.     * @param name       the new name.     */    static void setFixedNewMemberName(MemberInfo memberInfo, String name)    {        VisitorAccepter lastVisitorAccepter = MethodInfoLinker.lastVisitorAccepter(memberInfo);        if (!(lastVisitorAccepter instanceof LibraryMemberInfo) &&            !(lastVisitorAccepter instanceof MyFixedName))        {            lastVisitorAccepter.setVisitorInfo(new MyFixedName(name));        }        else        {            lastVisitorAccepter.setVisitorInfo(name);        }    }    /**     * Assigns a new name to the given class member.     * @param memberInfo the class member.     * @param name       the new name.     */    static void setNewMemberName(MemberInfo memberInfo, String name)    {        MethodInfoLinker.lastVisitorAccepter(memberInfo).setVisitorInfo(name);    }    /**     * Returns whether the new name of the given class member is fixed.     * @param memberInfo the given class member.     * @return whether its new name is fixed.     */    static boolean hasFixedNewMemberName(MemberInfo memberInfo)    {        VisitorAccepter lastVisitorAccepter = MethodInfoLinker.lastVisitorAccepter(memberInfo);        return lastVisitorAccepter instanceof LibraryMemberInfo ||               lastVisitorAccepter instanceof MyFixedName;    }    /**     * Retrieves the new name of the given class member.     * @param memberInfo the given class member.     * @return the class member's new name, or <code>null</code> if it doesn't     *         have one yet.     */    static String newMemberName(MemberInfo memberInfo)    {        return (String)MethodInfoLinker.lastVisitorAccepter(memberInfo).getVisitorInfo();    }    /**     * This VisitorAccepter can be used to wrap a name string, to indicate that     * the name is fixed.     */    private static class MyFixedName implements VisitorAccepter    {        private String newName;        public MyFixedName(String newName)        {            this.newName = newName;        }        // Implementations for VisitorAccepter.        public Object getVisitorInfo()        {            return newName;        }        public void setVisitorInfo(Object visitorInfo)        {            newName = (String)visitorInfo;        }    }}

⌨️ 快捷键说明

复制代码 Ctrl + C
搜索代码 Ctrl + F
全屏模式 F11
切换主题 Ctrl + Shift + D
显示快捷键 ?
增大字号 Ctrl + =
减小字号 Ctrl + -