• 设为首页
  • 点击收藏
  • 手机版
    手机扫一扫访问
    迪恩网络手机版
  • 关注官方公众号
    微信扫一扫关注
    公众号

Java Utils类代码示例

原作者: [db:作者] 来自: [db:来源] 收藏 邀请

本文整理汇总了Java中org.fdroid.fdroid.Utils的典型用法代码示例。如果您正苦于以下问题:Java Utils类的具体用法?Java Utils怎么用?Java Utils使用的例子?那么恭喜您, 这里精选的类代码示例或许可以为您提供帮助。



Utils类属于org.fdroid.fdroid包,在下文中一共展示了Utils类的20个代码示例,这些例子默认根据受欢迎程度排序。您可以为喜欢或者感觉有用的代码点赞,您的评价将有助于我们的系统推荐出更棒的Java代码示例。

示例1: onReceive

import org.fdroid.fdroid.Utils; //导入依赖的package包/类
@Override
public void onReceive(Context context, Intent intent) {
    if (intent != null) {
        String action = intent.getAction();
        if (Intent.ACTION_PACKAGE_ADDED.equals(action)) {
            InstalledAppProviderService.insert(context, intent.getData());
        } else if (Intent.ACTION_PACKAGE_REMOVED.equals(action)) {
            if (TextUtils.equals(context.getPackageName(), intent.getData().getSchemeSpecificPart())) {
                Utils.debugLog(TAG, "Ignoring request to remove ourselves from cache.");
            } else {
                InstalledAppProviderService.delete(context, intent.getData());
            }
        } else {
            Utils.debugLog(TAG, "unsupported action: " + action + " " + intent);
        }
    }
}
 
开发者ID:uhuru-mobile,项目名称:mobile-store,代码行数:18,代码来源:PackageManagerReceiver.java


示例2: processIntent

import org.fdroid.fdroid.Utils; //导入依赖的package包/类
private void processIntent(Intent i) {
    if (NfcAdapter.ACTION_NDEF_DISCOVERED.equals(i.getAction())) {
        Parcelable[] rawMsgs =
                i.getParcelableArrayExtra(NfcAdapter.EXTRA_NDEF_MESSAGES);
        NdefMessage msg = (NdefMessage) rawMsgs[0];
        String url = new String(msg.getRecords()[0].getPayload());
        Utils.debugLog(TAG, "Got this URL: " + url);
        Toast.makeText(this, "Got this URL: " + url, Toast.LENGTH_LONG).show();
        Intent intent = new Intent(Intent.ACTION_VIEW, Uri.parse(url));
        intent.setClass(this, ManageReposActivity.class);
        startActivity(intent);
        finish();
    }
}
 
开发者ID:uhuru-mobile,项目名称:mobile-store,代码行数:15,代码来源:RepoDetailsActivity.java


示例3: setupRepoFingerprint

import org.fdroid.fdroid.Utils; //导入依赖的package包/类
private void setupRepoFingerprint(View parent, Repo repo) {
    TextView repoFingerprintView = (TextView) parent.findViewById(R.id.text_repo_fingerprint);
    TextView repoFingerprintDescView = (TextView) parent.findViewById(R.id.text_repo_fingerprint_description);

    String repoFingerprint;

    // TODO show the current state of the signature check, not just whether there is a key or not
    if (TextUtils.isEmpty(repo.fingerprint) && TextUtils.isEmpty(repo.signingCertificate)) {
        repoFingerprint = getResources().getString(R.string.unsigned);
        repoFingerprintView.setTextColor(getResources().getColor(R.color.unsigned));
        repoFingerprintDescView.setVisibility(View.VISIBLE);
        repoFingerprintDescView.setText(getResources().getString(R.string.unsigned_description));
    } else {
        // this is based on repo.fingerprint always existing, which it should
        repoFingerprint = Utils.formatFingerprint(this, repo.fingerprint);
        repoFingerprintDescView.setVisibility(View.GONE);
    }

    repoFingerprintView.setText(repoFingerprint);
}
 
开发者ID:uhuru-mobile,项目名称:mobile-store,代码行数:21,代码来源:RepoDetailsActivity.java


示例4: updateAndEnableExistingRepo

import org.fdroid.fdroid.Utils; //导入依赖的package包/类
/**
 * Seeing as this repo already exists, we will force it to be enabled again.
 */
private void updateAndEnableExistingRepo(String url, String fingerprint) {
    if (fingerprint != null) {
        fingerprint = fingerprint.trim();
        if (TextUtils.isEmpty(fingerprint)) {
            fingerprint = null;
        } else {
            fingerprint = fingerprint.toUpperCase(Locale.ENGLISH);
        }
    }

    Utils.debugLog(TAG, "Enabling existing repo: " + url);
    Repo repo = RepoProvider.Helper.findByAddress(context, url);
    ContentValues values = new ContentValues(2);
    values.put(RepoTable.Cols.IN_USE, 1);
    values.put(RepoTable.Cols.FINGERPRINT, fingerprint);
    RepoProvider.Helper.update(context, repo, values);
    notifyDataSetChanged();
    finishedAddingRepo();
}
 
开发者ID:uhuru-mobile,项目名称:mobile-store,代码行数:23,代码来源:ManageReposActivity.java


示例5: requestedPermissionsEqual

import org.fdroid.fdroid.Utils; //导入依赖的package包/类
/**
 * Compares to sets of APK permissions to see if they are an exact match.  The
 * data format is {@link String} arrays but they are in effect sets. This is the
 * same data format as {@link android.content.pm.PackageInfo#requestedPermissions}
 */
public static boolean requestedPermissionsEqual(@Nullable String[] expected, @Nullable String[] actual) {
    Utils.debugLog(TAG, "Checking permissions");
    Utils.debugLog(TAG, "Actual:\n  " + (actual == null ? "None" : TextUtils.join("\n  ", actual)));
    Utils.debugLog(TAG, "Expected:\n  " + (expected == null ? "None" : TextUtils.join("\n  ", expected)));

    if (expected == null && actual == null) {
        return true;
    }
    if (expected == null || actual == null) {
        return false;
    }
    if (expected.length != actual.length) {
        return false;
    }
    HashSet<String> expectedSet = new HashSet<>(Arrays.asList(expected));
    HashSet<String> actualSet = new HashSet<>(Arrays.asList(actual));
    return expectedSet.equals(actualSet);
}
 
开发者ID:uhuru-mobile,项目名称:mobile-store,代码行数:24,代码来源:ApkVerifier.java


示例6: startBluetoothSwap

import org.fdroid.fdroid.Utils; //导入依赖的package包/类
/**
 * The process for setting up bluetooth is as follows:
 *  * Assume we have bluetooth available (otherwise the button which allowed us to start
 *    the bluetooth process should not have been available).
 *  * Ask user to enable (if not enabled yet).
 *  * Start bluetooth server socket.
 *  * Enable bluetooth discoverability, so that people can connect to our server socket.
 *
 * Note that this is a little different than the usual process for bluetooth _clients_, which
 * involves pairing and connecting with other devices.
 */
public void startBluetoothSwap() {

    Utils.debugLog(TAG, "Initiating Bluetooth swap, will ensure the Bluetooth devices is enabled and discoverable before starting server.");
    BluetoothAdapter adapter = BluetoothAdapter.getDefaultAdapter();

    if (adapter != null) {
        if (adapter.isEnabled()) {
            Utils.debugLog(TAG, "Bluetooth enabled, will check if device is discoverable with device.");
            ensureBluetoothDiscoverableThenStart();
        } else {
            Utils.debugLog(TAG, "Bluetooth disabled, asking user to enable it.");
            Intent enableBtIntent = new Intent(BluetoothAdapter.ACTION_REQUEST_ENABLE);
            startActivityForResult(enableBtIntent, REQUEST_BLUETOOTH_ENABLE_FOR_SWAP);
        }
    }
}
 
开发者ID:uhuru-mobile,项目名称:mobile-store,代码行数:28,代码来源:SwapWorkflowActivity.java


示例7: ensureBluetoothDiscoverableThenStart

import org.fdroid.fdroid.Utils; //导入依赖的package包/类
private void ensureBluetoothDiscoverableThenStart() {
    Utils.debugLog(TAG, "Ensuring Bluetooth is in discoverable mode.");
    if (BluetoothAdapter.getDefaultAdapter().getScanMode() != BluetoothAdapter.SCAN_MODE_CONNECTABLE_DISCOVERABLE) {

        // TODO: Listen for BluetoothAdapter.ACTION_SCAN_MODE_CHANGED and respond if discovery
        // is cancelled prematurely.

        // 3600 is new maximum! TODO: What about when this expires? What if user manually disables discovery?
        final int discoverableTimeout = 3600;

        Utils.debugLog(TAG, "Not currently in discoverable mode, so prompting user to enable.");
        Intent intent = new Intent(BluetoothAdapter.ACTION_REQUEST_DISCOVERABLE);
        intent.putExtra(BluetoothAdapter.EXTRA_DISCOVERABLE_DURATION, discoverableTimeout);
        startActivityForResult(intent, REQUEST_BLUETOOTH_DISCOVERABLE);
    }

    if (service == null) {
        throw new IllegalStateException("Can't start Bluetooth swap because service is null for some strange reason.");
    }

    service.getBluetoothSwap().startInBackground();
}
 
开发者ID:uhuru-mobile,项目名称:mobile-store,代码行数:23,代码来源:SwapWorkflowActivity.java


示例8: onCreate

import org.fdroid.fdroid.Utils; //导入依赖的package包/类
@Override
public void onCreate() {
    super.onCreate();
    Utils.debugLog(TAG, "creating Service");
    localBroadcastManager = LocalBroadcastManager.getInstance(this);
    appUpdateStatusManager = AppUpdateStatusManager.getInstance(this);

    BroadcastReceiver br = new BroadcastReceiver() {
        @Override
        public void onReceive(Context context, Intent intent) {
            String packageName = intent.getData().getSchemeSpecificPart();
            for (AppUpdateStatusManager.AppUpdateStatus status : appUpdateStatusManager.getByPackageName(packageName)) {
                appUpdateStatusManager.updateApk(status.getUniqueKey(), AppUpdateStatusManager.Status.Installed, null);
            }
        }
    };
    IntentFilter intentFilter = new IntentFilter();
    intentFilter.addAction(Intent.ACTION_PACKAGE_ADDED);
    intentFilter.addDataScheme("package");
    registerReceiver(br, intentFilter);
}
 
开发者ID:uhuru-mobile,项目名称:mobile-store,代码行数:22,代码来源:InstallManagerService.java


示例9: uiInitBluetooth

import org.fdroid.fdroid.Utils; //导入依赖的package包/类
private void uiInitBluetooth() {
    if (bluetooth != null) {

        textBluetoothVisible = (TextView) findViewById(R.id.bluetooth_visible);

        viewBluetoothId = (TextView) findViewById(R.id.device_id_bluetooth);
        viewBluetoothId.setText(bluetooth.getName());
        viewBluetoothId.setVisibility(bluetooth.isEnabled() ? View.VISIBLE : View.GONE);

        int textResource = getManager().isBluetoothDiscoverable() ? R.string.swap_visible_bluetooth : R.string.swap_not_visible_bluetooth;
        textBluetoothVisible.setText(textResource);

        bluetoothSwitch = (SwitchCompat) findViewById(R.id.switch_bluetooth);
        Utils.debugLog(TAG, getManager().isBluetoothDiscoverable() ? "Initially marking switch as checked, because Bluetooth is discoverable." : "Initially marking switch as not-checked, because Bluetooth is not discoverable.");
        bluetoothSwitch.setOnCheckedChangeListener(onBluetoothSwitchToggled);
        setBluetoothSwitchState(getManager().isBluetoothDiscoverable(), true);

        LocalBroadcastManager.getInstance(getContext()).registerReceiver(onBluetoothSwapStateChanged, new IntentFilter(SwapService.BLUETOOTH_STATE_CHANGE));

    } else {
        findViewById(R.id.bluetooth_info).setVisibility(View.GONE);
    }
}
 
开发者ID:uhuru-mobile,项目名称:mobile-store,代码行数:24,代码来源:StartSwapView.java


示例10: onReceive

import org.fdroid.fdroid.Utils; //导入依赖的package包/类
@Override
public void onReceive(Context context, Intent intent) {
    if (intent.hasExtra(SwapService.EXTRA_STARTING)) {
        Utils.debugLog(TAG, "Bluetooth service is starting (setting toggle to disabled, not checking because we will wait for an intent that bluetooth is actually enabled)");
        bluetoothSwitch.setEnabled(false);
        textBluetoothVisible.setText(R.string.swap_setting_up_bluetooth);
        // bluetoothSwitch.setChecked(true);
    } else {
        if (intent.hasExtra(SwapService.EXTRA_STARTED)) {
            Utils.debugLog(TAG, "Bluetooth service has started (updating text to visible, but not marking as checked).");
            textBluetoothVisible.setText(R.string.swap_visible_bluetooth);
            bluetoothSwitch.setEnabled(true);
            // bluetoothSwitch.setChecked(true);
        } else {
            Utils.debugLog(TAG, "Bluetooth service has stopped (setting switch to not-visible).");
            textBluetoothVisible.setText(R.string.swap_not_visible_bluetooth);
            setBluetoothSwitchState(false, true);
        }
    }
}
 
开发者ID:uhuru-mobile,项目名称:mobile-store,代码行数:21,代码来源:StartSwapView.java


示例11: onCheckedChanged

import org.fdroid.fdroid.Utils; //导入依赖的package包/类
@Override
public void onCheckedChanged(CompoundButton buttonView, boolean isChecked) {
    if (isChecked) {
        Utils.debugLog(TAG, "Received onCheckChanged(true) for Bluetooth swap, prompting user as to whether they want to enable Bluetooth.");
        getActivity().startBluetoothSwap();
        textBluetoothVisible.setText(R.string.swap_visible_bluetooth);
        viewBluetoothId.setVisibility(View.VISIBLE);
        Utils.debugLog(TAG, "Received onCheckChanged(true) for Bluetooth swap (prompting user or setup Bluetooth complete)");
        // TODO: When they deny the request for enabling bluetooth, we need to disable this switch...
    } else {
        Utils.debugLog(TAG, "Received onCheckChanged(false) for Bluetooth swap, disabling Bluetooth swap.");
        getManager().getBluetoothSwap().stop();
        textBluetoothVisible.setText(R.string.swap_not_visible_bluetooth);
        viewBluetoothId.setVisibility(View.GONE);
        Utils.debugLog(TAG, "Received onCheckChanged(false) for Bluetooth swap, Bluetooth swap disabled successfully.");
    }
}
 
开发者ID:uhuru-mobile,项目名称:mobile-store,代码行数:18,代码来源:StartSwapView.java


示例12: symlinkRuntime

import org.fdroid.fdroid.Utils; //导入依赖的package包/类
static void symlinkRuntime(SanitizedFile source, SanitizedFile dest) {
    String[] commands = {
        FDroidApp.SYSTEM_DIR_NAME + "/bin/ln",
        "-s",
        source.getAbsolutePath(),
        dest.getAbsolutePath(),
    };
    try {
        Utils.debugLog(TAG, "Executing command: " + commands[0] + " " + commands[1]
                + " " + commands[2] + " " + commands[3]);
        Process proc = Runtime.getRuntime().exec(commands);
        Utils.consumeStream(proc.getInputStream());
        Utils.consumeStream(proc.getErrorStream());
    } catch (IOException e) {
        // Do nothing
    }
}
 
开发者ID:uhuru-mobile,项目名称:mobile-store,代码行数:18,代码来源:FileCompat.java


示例13: onReceive

import org.fdroid.fdroid.Utils; //导入依赖的package包/类
@Override
public void onReceive(Context context, Intent intent) {
    int statusCode = intent.getIntExtra(UpdateService.EXTRA_STATUS_CODE, -1);
    switch (statusCode) {
        case UpdateService.STATUS_COMPLETE_WITH_CHANGES:
            Utils.debugLog(TAG, "Swap repo has updates, notifying the list adapter.");
            getActivity().runOnUiThread(new Runnable() {
                @Override
                public void run() {
                    adapter.notifyDataSetChanged();
                }
            });
            break;

        case UpdateService.STATUS_ERROR_GLOBAL:
            // TODO: Well, if we can't get the index, we probably can't swapp apps.
            // Tell the user something helpful?
            break;

        case UpdateService.STATUS_COMPLETE_AND_SAME:
            schedulePollForUpdates();
            break;
    }
}
 
开发者ID:uhuru-mobile,项目名称:mobile-store,代码行数:25,代码来源:SwapAppsView.java


示例14: lastUpdated

import org.fdroid.fdroid.Utils; //导入依赖的package包/类
@Test
public void lastUpdated() {
    assertNull(RepoProvider.Helper.lastUpdate(context));

    Repo gpRepo = RepoProvider.Helper.findByAddress(context, "https://guardianproject.info/fdroid/repo");

    // Set date to 2017-04-05 11:56:38
    setLastUpdate(gpRepo, new Date(1491357408643L));

    // GP is not yet enabled, so it is not counted.
    assertNull(RepoProvider.Helper.lastUpdate(context));

    // Set date to 2017-04-04 11:56:38
    Repo fdroidRepo = RepoProvider.Helper.findByAddress(context, "https://f-droid.org/repo");
    setLastUpdate(fdroidRepo, new Date(1491357408643L - (1000 * 60 * 60 * 24)));
    assertEquals("2017-04-04", Utils.formatDate(RepoProvider.Helper.lastUpdate(context), null));

    setEnabled(gpRepo, true);
    assertEquals("2017-04-05", Utils.formatDate(RepoProvider.Helper.lastUpdate(context), null));
}
 
开发者ID:uhuru-mobile,项目名称:mobile-store,代码行数:21,代码来源:RepoProviderTest.java


示例15: addAppPrefsTable

import org.fdroid.fdroid.Utils; //导入依赖的package包/类
private void addAppPrefsTable(SQLiteDatabase db, int oldVersion) {
    if (oldVersion >= 60) {
        return;
    }

    Utils.debugLog(TAG, "Creating app preferences table");
    db.execSQL(CREATE_TABLE_APP_PREFS);

    Utils.debugLog(TAG, "Migrating app preferences to separate table");
    db.execSQL(
            "INSERT INTO " + AppPrefsTable.NAME + " ("
            + AppPrefsTable.Cols.PACKAGE_NAME + ", "
            + AppPrefsTable.Cols.IGNORE_THIS_UPDATE + ", "
            + AppPrefsTable.Cols.IGNORE_ALL_UPDATES
            + ") SELECT "
            + "id, "
            + "ignoreThisUpdate, "
            + "ignoreAllUpdates "
            + "FROM " + AppMetadataTable.NAME + " "
            + "WHERE ignoreThisUpdate > 0 OR ignoreAllUpdates > 0"
    );

    resetTransient(db);
}
 
开发者ID:uhuru-mobile,项目名称:mobile-store,代码行数:25,代码来源:DBHelper.java


示例16: migrateAppPrimaryKeyToRowId

import org.fdroid.fdroid.Utils; //导入依赖的package包/类
private void migrateAppPrimaryKeyToRowId(SQLiteDatabase db, int oldVersion) {
    if (oldVersion < 58 && !columnExists(db, ApkTable.NAME, ApkTable.Cols.APP_ID)) {
        db.beginTransaction();
        try {
            final String alter = "ALTER TABLE " + ApkTable.NAME + " ADD COLUMN " + ApkTable.Cols.APP_ID + " NUMERIC";
            Log.i(TAG, "Adding appId foreign key to " + ApkTable.NAME);
            Utils.debugLog(TAG, alter);
            db.execSQL(alter);

            // Hard coded the string literal ".id" as ApkTable.Cols.PACKAGE_NAME was removed in
            // the subsequent migration (DB_VERSION 59)
            final String update = "UPDATE " + ApkTable.NAME + " SET " + ApkTable.Cols.APP_ID + " = ( " +
                    "SELECT app." + AppMetadataTable.Cols.ROW_ID + " " +
                    "FROM " + AppMetadataTable.NAME + " AS app " +
                    "WHERE " + ApkTable.NAME + ".id = app.id)";
            Log.i(TAG, "Updating foreign key from " + ApkTable.NAME + " to " + AppMetadataTable.NAME + " to use numeric foreign key.");
            Utils.debugLog(TAG, update);
            db.execSQL(update);
            ensureIndexes(db);
            db.setTransactionSuccessful();
        } finally {
            db.endTransaction();
        }
    }
}
 
开发者ID:uhuru-mobile,项目名称:mobile-store,代码行数:26,代码来源:DBHelper.java


示例17: populateRepoNames

import org.fdroid.fdroid.Utils; //导入依赖的package包/类
private void populateRepoNames(SQLiteDatabase db, int oldVersion) {
    if (oldVersion >= 37) {
        return;
    }
    Utils.debugLog(TAG, "Populating repo names from the url");
    final String[] columns = {RepoTable.Cols.ADDRESS, RepoTable.Cols._ID};
    Cursor cursor = db.query(RepoTable.NAME, columns,
            RepoTable.Cols.NAME + " IS NULL OR " + RepoTable.Cols.NAME + " = ''", null, null, null, null);
    if (cursor != null) {
        if (cursor.getCount() > 0) {
            cursor.moveToFirst();
            while (!cursor.isAfterLast()) {
                String address = cursor.getString(0);
                long id = cursor.getInt(1);
                ContentValues values = new ContentValues(1);
                String name = Repo.addressToName(address);
                values.put(RepoTable.Cols.NAME, name);
                final String[] args = {Long.toString(id)};
                Utils.debugLog(TAG, "Setting repo name to '" + name + "' for repo " + address);
                db.update(RepoTable.NAME, values, RepoTable.Cols._ID + " = ?", args);
                cursor.moveToNext();
            }
        }
        cursor.close();
    }
}
 
开发者ID:uhuru-mobile,项目名称:mobile-store,代码行数:27,代码来源:DBHelper.java


示例18: onHandleIntent

import org.fdroid.fdroid.Utils; //导入依赖的package包/类
@Override
protected void onHandleIntent(Intent intent) {
    android.os.Process.setThreadPriority(android.os.Process.THREAD_PRIORITY_LOWEST);
    if (intent == null || !ACTION_PARSE_APP.equals(intent.getAction())) {
        Utils.debugLog(TAG, "received bad Intent: " + intent);
        return;
    }

    try {
        PackageManager pm = getPackageManager();
        String packageName = intent.getData().getSchemeSpecificPart();
        App app = new App(this, pm, packageName);
        SwapService.putAppInCache(packageName, app);
    } catch (CertificateEncodingException | IOException | PackageManager.NameNotFoundException e) {
        e.printStackTrace();
    }
}
 
开发者ID:uhuru-mobile,项目名称:mobile-store,代码行数:18,代码来源:CacheSwapAppsService.java


示例19: delete

import org.fdroid.fdroid.Utils; //导入依赖的package包/类
@Override
public int delete(Uri uri, String where, String[] whereArgs) {

    QuerySelection selection = new QuerySelection(where, whereArgs);
    switch (MATCHER.match(uri)) {
        case CODE_LIST:
            // Don't support deleting of multiple repos.
            return 0;

        case CODE_SINGLE:
            selection = selection.add(Cols._ID + " = ?", new String[]{uri.getLastPathSegment()});
            break;

        default:
            Log.e(TAG, "Invalid URI for repo content provider: " + uri);
            throw new UnsupportedOperationException("Invalid URI for repo content provider: " + uri);
    }

    int rowsAffected = db().delete(getTableName(), selection.getSelection(), selection.getArgs());
    Utils.debugLog(TAG, "Deleted repo. Notifying provider change: '" + uri + "'.");
    getContext().getContentResolver().notifyChange(uri, null);
    return rowsAffected;
}
 
开发者ID:uhuru-mobile,项目名称:mobile-store,代码行数:24,代码来源:RepoProvider.java


示例20: send

import org.fdroid.fdroid.Utils; //导入依赖的package包/类
public void send(BluetoothConnection connection) throws IOException {

        Utils.debugLog(TAG, "Sending Bluetooth HTTP-ish response...");

        Writer output = new OutputStreamWriter(connection.getOutputStream());
        output.write("HTTP(ish)/0.1 200 OK\n");

        for (Map.Entry<String, String> entry : headers.entrySet()) {
            output.write(entry.getKey());
            output.write(": ");
            output.write(entry.getValue());
            output.write("\n");
        }

        output.write("\n");
        output.flush();

        if (contentStream != null) {
            Utils.copy(contentStream, connection.getOutputStream());
        }

        output.flush();

    }
 
开发者ID:uhuru-mobile,项目名称:mobile-store,代码行数:25,代码来源:Response.java



注:本文中的org.fdroid.fdroid.Utils类示例整理自Github/MSDocs等源码及文档管理平台,相关代码片段筛选自各路编程大神贡献的开源项目,源码版权归原作者所有,传播和使用请参考对应项目的License;未经允许,请勿转载。


鲜花

握手

雷人

路过

鸡蛋
该文章已有0人参与评论

请发表评论

全部评论

专题导读
上一篇:
Java EntityMetadata类代码示例发布时间:2022-05-22
下一篇:
Java JDBCDataStore类代码示例发布时间:2022-05-22
热门推荐
阅读排行榜

扫描微信二维码

查看手机版网站

随时了解更新最新资讯

139-2527-9053

在线客服(服务时间 9:00~18:00)

在线QQ客服
地址:深圳市南山区西丽大学城创智工业园
电邮:jeky_zhao#qq.com
移动电话:139-2527-9053

Powered by 互联科技 X3.4© 2001-2213 极客世界.|Sitemap